blob: bfe524954872feaa82cc9d167d1a9fcf7a20ce1a [file] [log] [blame]
/**
* @license
* Copyright 2016 Google Inc. All rights reserved.
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package com.google.security.wycheproof;
import com.google.security.wycheproof.WycheproofRunner.ExcludedTest;
import com.google.security.wycheproof.WycheproofRunner.ProviderType;
import java.math.BigInteger;
import java.security.KeyFactory;
import java.security.KeyPair;
import java.security.KeyPairGenerator;
import java.security.interfaces.RSAPrivateCrtKey;
import java.security.interfaces.RSAPrivateKey;
import java.security.interfaces.RSAPublicKey;
import java.security.spec.InvalidKeySpecException;
import java.security.spec.X509EncodedKeySpec;
import junit.framework.TestCase;
/**
* Tests RSA keys. Signatures and encryption are tested in different tests.
*
* @author bleichen@google.com (Daniel Bleichenbacher)
*/
// TODO(bleichen):
// - Add checks for bad random numbers
// - expect keys with e=1 to be rejected
// - expect keys with e=0 to be rejected
// - document stuff
// - Maybe also check encodings of private keys.
// - Test multi prime RSA
// - Tests for alternative representations:
// many libraries sort the primes as: p > q (but not all)
// some libraries compute d mod lambda(n)
// paramaters p,q,... are not really required
// - checks for bad random number generation
public class RsaKeyTest extends TestCase {
public static final String ENCODED_PUBLIC_KEY =
"30819f300d06092a864886f70d010101050003818d0030818902818100ab9014"
+ "dc47d44b6d260fc1fef9ab022042fd9566e9d7b60c54100cb6e1d4edc9859046"
+ "7d0502c17fce69d00ac5efb40b2cb167d8a44ab93d73c4d0f109fb5a26c2f882"
+ "3236ff517cf84412e173679cfae42e043b6fec81f9d984b562517e6febe1f722"
+ "95dbc3fdfc19d3240aa75515563f31dad83563f3a315acf9a0b351a23f020301"
+ "0001";
/**
* Encodings of the public key from ENCODED_PUBLIC_KEY with modifications.
* This list so far has just a simple purpose: it is used to check whether parsing the key
* leads to some unexpected exceptions. I.e. it should not be possible to crash an
* application with an modified public key.
*/
public static final String[] MODIFIED_PUBLIC_KEY = {
// length contains leading 0
"3082009f300d06092a864886f70d010101050003818d0030818902818100ab90"
+ "14dc47d44b6d260fc1fef9ab022042fd9566e9d7b60c54100cb6e1d4edc98590"
+ "467d0502c17fce69d00ac5efb40b2cb167d8a44ab93d73c4d0f109fb5a26c2f8"
+ "823236ff517cf84412e173679cfae42e043b6fec81f9d984b562517e6febe1f7"
+ "2295dbc3fdfc19d3240aa75515563f31dad83563f3a315acf9a0b351a23f0203"
+ "010001",
"3081a13082000d06092a864886f70d010101050003818d0030818902818100ab"
+ "9014dc47d44b6d260fc1fef9ab022042fd9566e9d7b60c54100cb6e1d4edc985"
+ "90467d0502c17fce69d00ac5efb40b2cb167d8a44ab93d73c4d0f109fb5a26c2"
+ "f8823236ff517cf84412e173679cfae42e043b6fec81f9d984b562517e6febe1"
+ "f72295dbc3fdfc19d3240aa75515563f31dad83563f3a315acf9a0b351a23f02"
+ "03010001",
"3081a1300f068200092a864886f70d010101050003818d0030818902818100ab"
+ "9014dc47d44b6d260fc1fef9ab022042fd9566e9d7b60c54100cb6e1d4edc985"
+ "90467d0502c17fce69d00ac5efb40b2cb167d8a44ab93d73c4d0f109fb5a26c2"
+ "f8823236ff517cf84412e173679cfae42e043b6fec81f9d984b562517e6febe1"
+ "f72295dbc3fdfc19d3240aa75515563f31dad83563f3a315acf9a0b351a23f02"
+ "03010001",
"3081a1300f06092a864886f70d0101010582000003818d0030818902818100ab"
+ "9014dc47d44b6d260fc1fef9ab022042fd9566e9d7b60c54100cb6e1d4edc985"
+ "90467d0502c17fce69d00ac5efb40b2cb167d8a44ab93d73c4d0f109fb5a26c2"
+ "f8823236ff517cf84412e173679cfae42e043b6fec81f9d984b562517e6febe1"
+ "f72295dbc3fdfc19d3240aa75515563f31dad83563f3a315acf9a0b351a23f02"
+ "03010001",
"3081a0300d06092a864886f70d01010105000382008d0030818902818100ab90"
+ "14dc47d44b6d260fc1fef9ab022042fd9566e9d7b60c54100cb6e1d4edc98590"
+ "467d0502c17fce69d00ac5efb40b2cb167d8a44ab93d73c4d0f109fb5a26c2f8"
+ "823236ff517cf84412e173679cfae42e043b6fec81f9d984b562517e6febe1f7"
+ "2295dbc3fdfc19d3240aa75515563f31dad83563f3a315acf9a0b351a23f0203"
+ "010001",
"30819f300d06092a864886f70d010101050003818d3082008902818100ab9014"
+ "dc47d44b6d260fc1fef9ab022042fd9566e9d7b60c54100cb6e1d4edc9859046"
+ "7d0502c17fce69d00ac5efb40b2cb167d8a44ab93d73c4d0f109fb5a26c2f882"
+ "3236ff517cf84412e173679cfae42e043b6fec81f9d984b562517e6febe1f722"
+ "95dbc3fdfc19d3240aa75515563f31dad83563f3a315acf9a0b351a23f020301"
+ "0001",
"30819f300d06092a864886f70d010101050003818d30818a0282008100ab9014"
+ "dc47d44b6d260fc1fef9ab022042fd9566e9d7b60c54100cb6e1d4edc9859046"
+ "7d0502c17fce69d00ac5efb40b2cb167d8a44ab93d73c4d0f109fb5a26c2f882"
+ "3236ff517cf84412e173679cfae42e043b6fec81f9d984b562517e6febe1f722"
+ "95dbc3fdfc19d3240aa75515563f31dad83563f3a315acf9a0b351a23f020301"
+ "0001",
"3081a0300d06092a864886f70d010101050003818e30818b02818100ab9014dc"
+ "47d44b6d260fc1fef9ab022042fd9566e9d7b60c54100cb6e1d4edc98590467d"
+ "0502c17fce69d00ac5efb40b2cb167d8a44ab93d73c4d0f109fb5a26c2f88232"
+ "36ff517cf84412e173679cfae42e043b6fec81f9d984b562517e6febe1f72295"
+ "dbc3fdfc19d3240aa75515563f31dad83563f3a315acf9a0b351a23f02820003"
+ "010001",
// wrong length
"30a0300d06092a864886f70d010101050003818d0030818902818100ab9014dc"
+ "47d44b6d260fc1fef9ab022042fd9566e9d7b60c54100cb6e1d4edc98590467d"
+ "0502c17fce69d00ac5efb40b2cb167d8a44ab93d73c4d0f109fb5a26c2f88232"
+ "36ff517cf84412e173679cfae42e043b6fec81f9d984b562517e6febe1f72295"
+ "dbc3fdfc19d3240aa75515563f31dad83563f3a315acf9a0b351a23f02030100"
+ "01",
"309e300d06092a864886f70d010101050003818d0030818902818100ab9014dc"
+ "47d44b6d260fc1fef9ab022042fd9566e9d7b60c54100cb6e1d4edc98590467d"
+ "0502c17fce69d00ac5efb40b2cb167d8a44ab93d73c4d0f109fb5a26c2f88232"
+ "36ff517cf84412e173679cfae42e043b6fec81f9d984b562517e6febe1f72295"
+ "dbc3fdfc19d3240aa75515563f31dad83563f3a315acf9a0b351a23f02030100"
+ "01",
"30819f300e06092a864886f70d010101050003818d0030818902818100ab9014"
+ "dc47d44b6d260fc1fef9ab022042fd9566e9d7b60c54100cb6e1d4edc9859046"
+ "7d0502c17fce69d00ac5efb40b2cb167d8a44ab93d73c4d0f109fb5a26c2f882"
+ "3236ff517cf84412e173679cfae42e043b6fec81f9d984b562517e6febe1f722"
+ "95dbc3fdfc19d3240aa75515563f31dad83563f3a315acf9a0b351a23f020301"
+ "0001",
"30819f300c06092a864886f70d010101050003818d0030818902818100ab9014"
+ "dc47d44b6d260fc1fef9ab022042fd9566e9d7b60c54100cb6e1d4edc9859046"
+ "7d0502c17fce69d00ac5efb40b2cb167d8a44ab93d73c4d0f109fb5a26c2f882"
+ "3236ff517cf84412e173679cfae42e043b6fec81f9d984b562517e6febe1f722"
+ "95dbc3fdfc19d3240aa75515563f31dad83563f3a315acf9a0b351a23f020301"
+ "0001",
"30819f300d060a2a864886f70d010101050003818d0030818902818100ab9014"
+ "dc47d44b6d260fc1fef9ab022042fd9566e9d7b60c54100cb6e1d4edc9859046"
+ "7d0502c17fce69d00ac5efb40b2cb167d8a44ab93d73c4d0f109fb5a26c2f882"
+ "3236ff517cf84412e173679cfae42e043b6fec81f9d984b562517e6febe1f722"
+ "95dbc3fdfc19d3240aa75515563f31dad83563f3a315acf9a0b351a23f020301"
+ "0001",
"30819f300d06082a864886f70d010101050003818d0030818902818100ab9014"
+ "dc47d44b6d260fc1fef9ab022042fd9566e9d7b60c54100cb6e1d4edc9859046"
+ "7d0502c17fce69d00ac5efb40b2cb167d8a44ab93d73c4d0f109fb5a26c2f882"
+ "3236ff517cf84412e173679cfae42e043b6fec81f9d984b562517e6febe1f722"
+ "95dbc3fdfc19d3240aa75515563f31dad83563f3a315acf9a0b351a23f020301"
+ "0001",
"30819f300d06092a864886f70d010101050103818d0030818902818100ab9014"
+ "dc47d44b6d260fc1fef9ab022042fd9566e9d7b60c54100cb6e1d4edc9859046"
+ "7d0502c17fce69d00ac5efb40b2cb167d8a44ab93d73c4d0f109fb5a26c2f882"
+ "3236ff517cf84412e173679cfae42e043b6fec81f9d984b562517e6febe1f722"
+ "95dbc3fdfc19d3240aa75515563f31dad83563f3a315acf9a0b351a23f020301"
+ "0001",
"30819e300d06092a864886f70d0101010500038e0030818902818100ab9014dc"
+ "47d44b6d260fc1fef9ab022042fd9566e9d7b60c54100cb6e1d4edc98590467d"
+ "0502c17fce69d00ac5efb40b2cb167d8a44ab93d73c4d0f109fb5a26c2f88232"
+ "36ff517cf84412e173679cfae42e043b6fec81f9d984b562517e6febe1f72295"
+ "dbc3fdfc19d3240aa75515563f31dad83563f3a315acf9a0b351a23f02030100"
+ "01",
"30819e300d06092a864886f70d0101010500038c0030818902818100ab9014dc"
+ "47d44b6d260fc1fef9ab022042fd9566e9d7b60c54100cb6e1d4edc98590467d"
+ "0502c17fce69d00ac5efb40b2cb167d8a44ab93d73c4d0f109fb5a26c2f88232"
+ "36ff517cf84412e173679cfae42e043b6fec81f9d984b562517e6febe1f72295"
+ "dbc3fdfc19d3240aa75515563f31dad83563f3a315acf9a0b351a23f02030100"
+ "01",
"30819d300d06092a864886f70d010101050003818b308a02818100ab9014dc47"
+ "d44b6d260fc1fef9ab022042fd9566e9d7b60c54100cb6e1d4edc98590467d05"
+ "02c17fce69d00ac5efb40b2cb167d8a44ab93d73c4d0f109fb5a26c2f8823236"
+ "ff517cf84412e173679cfae42e043b6fec81f9d984b562517e6febe1f72295db"
+ "c3fdfc19d3240aa75515563f31dad83563f3a315acf9a0b351a23f0203010001",
"30819d300d06092a864886f70d010101050003818b308802818100ab9014dc47"
+ "d44b6d260fc1fef9ab022042fd9566e9d7b60c54100cb6e1d4edc98590467d05"
+ "02c17fce69d00ac5efb40b2cb167d8a44ab93d73c4d0f109fb5a26c2f8823236"
+ "ff517cf84412e173679cfae42e043b6fec81f9d984b562517e6febe1f72295db"
+ "c3fdfc19d3240aa75515563f31dad83563f3a315acf9a0b351a23f0203010001",
"30819d300d06092a864886f70d010101050003818b308188028200ab9014dc47"
+ "d44b6d260fc1fef9ab022042fd9566e9d7b60c54100cb6e1d4edc98590467d05"
+ "02c17fce69d00ac5efb40b2cb167d8a44ab93d73c4d0f109fb5a26c2f8823236"
+ "ff517cf84412e173679cfae42e043b6fec81f9d984b562517e6febe1f72295db"
+ "c3fdfc19d3240aa75515563f31dad83563f3a315acf9a0b351a23f0203010001",
"30819d300d06092a864886f70d010101050003818b308188028000ab9014dc47"
+ "d44b6d260fc1fef9ab022042fd9566e9d7b60c54100cb6e1d4edc98590467d05"
+ "02c17fce69d00ac5efb40b2cb167d8a44ab93d73c4d0f109fb5a26c2f8823236"
+ "ff517cf84412e173679cfae42e043b6fec81f9d984b562517e6febe1f72295db"
+ "c3fdfc19d3240aa75515563f31dad83563f3a315acf9a0b351a23f0203010001",
"30819e300d06092a864886f70d010101050003818c30818902818100ab9014dc"
+ "47d44b6d260fc1fef9ab022042fd9566e9d7b60c54100cb6e1d4edc98590467d"
+ "0502c17fce69d00ac5efb40b2cb167d8a44ab93d73c4d0f109fb5a26c2f88232"
+ "36ff517cf84412e173679cfae42e043b6fec81f9d984b562517e6febe1f72295"
+ "dbc3fdfc19d3240aa75515563f31dad83563f3a315acf9a0b351a23f02040100"
+ "01",
"30819e300d06092a864886f70d010101050003818c30818902818100ab9014dc"
+ "47d44b6d260fc1fef9ab022042fd9566e9d7b60c54100cb6e1d4edc98590467d"
+ "0502c17fce69d00ac5efb40b2cb167d8a44ab93d73c4d0f109fb5a26c2f88232"
+ "36ff517cf84412e173679cfae42e043b6fec81f9d984b562517e6febe1f72295"
+ "dbc3fdfc19d3240aa75515563f31dad83563f3a315acf9a0b351a23f02020100"
+ "01",
// uint32 overflow in length
"3085010000009f300d06092a864886f70d010101050003818d00308189028181"
+ "00ab9014dc47d44b6d260fc1fef9ab022042fd9566e9d7b60c54100cb6e1d4ed"
+ "c98590467d0502c17fce69d00ac5efb40b2cb167d8a44ab93d73c4d0f109fb5a"
+ "26c2f8823236ff517cf84412e173679cfae42e043b6fec81f9d984b562517e6f"
+ "ebe1f72295dbc3fdfc19d3240aa75515563f31dad83563f3a315acf9a0b351a2"
+ "3f0203010001",
"3081a43085010000000d06092a864886f70d010101050003818d003081890281"
+ "8100ab9014dc47d44b6d260fc1fef9ab022042fd9566e9d7b60c54100cb6e1d4"
+ "edc98590467d0502c17fce69d00ac5efb40b2cb167d8a44ab93d73c4d0f109fb"
+ "5a26c2f8823236ff517cf84412e173679cfae42e043b6fec81f9d984b562517e"
+ "6febe1f72295dbc3fdfc19d3240aa75515563f31dad83563f3a315acf9a0b351"
+ "a23f0203010001",
"3081a43012068501000000092a864886f70d010101050003818d003081890281"
+ "8100ab9014dc47d44b6d260fc1fef9ab022042fd9566e9d7b60c54100cb6e1d4"
+ "edc98590467d0502c17fce69d00ac5efb40b2cb167d8a44ab93d73c4d0f109fb"
+ "5a26c2f8823236ff517cf84412e173679cfae42e043b6fec81f9d984b562517e"
+ "6febe1f72295dbc3fdfc19d3240aa75515563f31dad83563f3a315acf9a0b351"
+ "a23f0203010001",
"3081a4301206092a864886f70d0101010585010000000003818d003081890281"
+ "8100ab9014dc47d44b6d260fc1fef9ab022042fd9566e9d7b60c54100cb6e1d4"
+ "edc98590467d0502c17fce69d00ac5efb40b2cb167d8a44ab93d73c4d0f109fb"
+ "5a26c2f8823236ff517cf84412e173679cfae42e043b6fec81f9d984b562517e"
+ "6febe1f72295dbc3fdfc19d3240aa75515563f31dad83563f3a315acf9a0b351"
+ "a23f0203010001",
"3081a3300d06092a864886f70d01010105000385010000008d00308189028181"
+ "00ab9014dc47d44b6d260fc1fef9ab022042fd9566e9d7b60c54100cb6e1d4ed"
+ "c98590467d0502c17fce69d00ac5efb40b2cb167d8a44ab93d73c4d0f109fb5a"
+ "26c2f8823236ff517cf84412e173679cfae42e043b6fec81f9d984b562517e6f"
+ "ebe1f72295dbc3fdfc19d3240aa75515563f31dad83563f3a315acf9a0b351a2"
+ "3f0203010001",
"3081a2300d06092a864886f70d01010105000381903085010000008902818100"
+ "ab9014dc47d44b6d260fc1fef9ab022042fd9566e9d7b60c54100cb6e1d4edc9"
+ "8590467d0502c17fce69d00ac5efb40b2cb167d8a44ab93d73c4d0f109fb5a26"
+ "c2f8823236ff517cf84412e173679cfae42e043b6fec81f9d984b562517e6feb"
+ "e1f72295dbc3fdfc19d3240aa75515563f31dad83563f3a315acf9a0b351a23f"
+ "0203010001",
"3081a2300d06092a864886f70d010101050003819030818d0285010000008100"
+ "ab9014dc47d44b6d260fc1fef9ab022042fd9566e9d7b60c54100cb6e1d4edc9"
+ "8590467d0502c17fce69d00ac5efb40b2cb167d8a44ab93d73c4d0f109fb5a26"
+ "c2f8823236ff517cf84412e173679cfae42e043b6fec81f9d984b562517e6feb"
+ "e1f72295dbc3fdfc19d3240aa75515563f31dad83563f3a315acf9a0b351a23f"
+ "0203010001",
"3081a3300d06092a864886f70d010101050003819130818e02818100ab9014dc"
+ "47d44b6d260fc1fef9ab022042fd9566e9d7b60c54100cb6e1d4edc98590467d"
+ "0502c17fce69d00ac5efb40b2cb167d8a44ab93d73c4d0f109fb5a26c2f88232"
+ "36ff517cf84412e173679cfae42e043b6fec81f9d984b562517e6febe1f72295"
+ "dbc3fdfc19d3240aa75515563f31dad83563f3a315acf9a0b351a23f02850100"
+ "000003010001",
// uint64 overflow in length
"308901000000000000009f300d06092a864886f70d010101050003818d003081"
+ "8902818100ab9014dc47d44b6d260fc1fef9ab022042fd9566e9d7b60c54100c"
+ "b6e1d4edc98590467d0502c17fce69d00ac5efb40b2cb167d8a44ab93d73c4d0"
+ "f109fb5a26c2f8823236ff517cf84412e173679cfae42e043b6fec81f9d984b5"
+ "62517e6febe1f72295dbc3fdfc19d3240aa75515563f31dad83563f3a315acf9"
+ "a0b351a23f0203010001",
"3081a8308901000000000000000d06092a864886f70d010101050003818d0030"
+ "818902818100ab9014dc47d44b6d260fc1fef9ab022042fd9566e9d7b60c5410"
+ "0cb6e1d4edc98590467d0502c17fce69d00ac5efb40b2cb167d8a44ab93d73c4"
+ "d0f109fb5a26c2f8823236ff517cf84412e173679cfae42e043b6fec81f9d984"
+ "b562517e6febe1f72295dbc3fdfc19d3240aa75515563f31dad83563f3a315ac"
+ "f9a0b351a23f0203010001",
"3081a8301606890100000000000000092a864886f70d010101050003818d0030"
+ "818902818100ab9014dc47d44b6d260fc1fef9ab022042fd9566e9d7b60c5410"
+ "0cb6e1d4edc98590467d0502c17fce69d00ac5efb40b2cb167d8a44ab93d73c4"
+ "d0f109fb5a26c2f8823236ff517cf84412e173679cfae42e043b6fec81f9d984"
+ "b562517e6febe1f72295dbc3fdfc19d3240aa75515563f31dad83563f3a315ac"
+ "f9a0b351a23f0203010001",
"3081a8301606092a864886f70d010101058901000000000000000003818d0030"
+ "818902818100ab9014dc47d44b6d260fc1fef9ab022042fd9566e9d7b60c5410"
+ "0cb6e1d4edc98590467d0502c17fce69d00ac5efb40b2cb167d8a44ab93d73c4"
+ "d0f109fb5a26c2f8823236ff517cf84412e173679cfae42e043b6fec81f9d984"
+ "b562517e6febe1f72295dbc3fdfc19d3240aa75515563f31dad83563f3a315ac"
+ "f9a0b351a23f0203010001",
"3081a7300d06092a864886f70d0101010500038901000000000000008d003081"
+ "8902818100ab9014dc47d44b6d260fc1fef9ab022042fd9566e9d7b60c54100c"
+ "b6e1d4edc98590467d0502c17fce69d00ac5efb40b2cb167d8a44ab93d73c4d0"
+ "f109fb5a26c2f8823236ff517cf84412e173679cfae42e043b6fec81f9d984b5"
+ "62517e6febe1f72295dbc3fdfc19d3240aa75515563f31dad83563f3a315acf9"
+ "a0b351a23f0203010001",
"3081a6300d06092a864886f70d01010105000381943089010000000000000089"
+ "02818100ab9014dc47d44b6d260fc1fef9ab022042fd9566e9d7b60c54100cb6"
+ "e1d4edc98590467d0502c17fce69d00ac5efb40b2cb167d8a44ab93d73c4d0f1"
+ "09fb5a26c2f8823236ff517cf84412e173679cfae42e043b6fec81f9d984b562"
+ "517e6febe1f72295dbc3fdfc19d3240aa75515563f31dad83563f3a315acf9a0"
+ "b351a23f0203010001",
"3081a6300d06092a864886f70d01010105000381943081910289010000000000"
+ "00008100ab9014dc47d44b6d260fc1fef9ab022042fd9566e9d7b60c54100cb6"
+ "e1d4edc98590467d0502c17fce69d00ac5efb40b2cb167d8a44ab93d73c4d0f1"
+ "09fb5a26c2f8823236ff517cf84412e173679cfae42e043b6fec81f9d984b562"
+ "517e6febe1f72295dbc3fdfc19d3240aa75515563f31dad83563f3a315acf9a0"
+ "b351a23f0203010001",
"3081a7300d06092a864886f70d010101050003819530819202818100ab9014dc"
+ "47d44b6d260fc1fef9ab022042fd9566e9d7b60c54100cb6e1d4edc98590467d"
+ "0502c17fce69d00ac5efb40b2cb167d8a44ab93d73c4d0f109fb5a26c2f88232"
+ "36ff517cf84412e173679cfae42e043b6fec81f9d984b562517e6febe1f72295"
+ "dbc3fdfc19d3240aa75515563f31dad83563f3a315acf9a0b351a23f02890100"
+ "00000000000003010001",
// length = 2**32 - 1
"3084ffffffff300d06092a864886f70d010101050003818d0030818902818100"
+ "ab9014dc47d44b6d260fc1fef9ab022042fd9566e9d7b60c54100cb6e1d4edc9"
+ "8590467d0502c17fce69d00ac5efb40b2cb167d8a44ab93d73c4d0f109fb5a26"
+ "c2f8823236ff517cf84412e173679cfae42e043b6fec81f9d984b562517e6feb"
+ "e1f72295dbc3fdfc19d3240aa75515563f31dad83563f3a315acf9a0b351a23f"
+ "0203010001",
"3081a33084ffffffff06092a864886f70d010101050003818d00308189028181"
+ "00ab9014dc47d44b6d260fc1fef9ab022042fd9566e9d7b60c54100cb6e1d4ed"
+ "c98590467d0502c17fce69d00ac5efb40b2cb167d8a44ab93d73c4d0f109fb5a"
+ "26c2f8823236ff517cf84412e173679cfae42e043b6fec81f9d984b562517e6f"
+ "ebe1f72295dbc3fdfc19d3240aa75515563f31dad83563f3a315acf9a0b351a2"
+ "3f0203010001",
"3081a330110684ffffffff2a864886f70d010101050003818d00308189028181"
+ "00ab9014dc47d44b6d260fc1fef9ab022042fd9566e9d7b60c54100cb6e1d4ed"
+ "c98590467d0502c17fce69d00ac5efb40b2cb167d8a44ab93d73c4d0f109fb5a"
+ "26c2f8823236ff517cf84412e173679cfae42e043b6fec81f9d984b562517e6f"
+ "ebe1f72295dbc3fdfc19d3240aa75515563f31dad83563f3a315acf9a0b351a2"
+ "3f0203010001",
"3081a3301106092a864886f70d0101010584ffffffff03818d00308189028181"
+ "00ab9014dc47d44b6d260fc1fef9ab022042fd9566e9d7b60c54100cb6e1d4ed"
+ "c98590467d0502c17fce69d00ac5efb40b2cb167d8a44ab93d73c4d0f109fb5a"
+ "26c2f8823236ff517cf84412e173679cfae42e043b6fec81f9d984b562517e6f"
+ "ebe1f72295dbc3fdfc19d3240aa75515563f31dad83563f3a315acf9a0b351a2"
+ "3f0203010001",
"3081a2300d06092a864886f70d01010105000384ffffffff0030818902818100"
+ "ab9014dc47d44b6d260fc1fef9ab022042fd9566e9d7b60c54100cb6e1d4edc9"
+ "8590467d0502c17fce69d00ac5efb40b2cb167d8a44ab93d73c4d0f109fb5a26"
+ "c2f8823236ff517cf84412e173679cfae42e043b6fec81f9d984b562517e6feb"
+ "e1f72295dbc3fdfc19d3240aa75515563f31dad83563f3a315acf9a0b351a23f"
+ "0203010001",
"3081a1300d06092a864886f70d010101050003818f3084ffffffff02818100ab"
+ "9014dc47d44b6d260fc1fef9ab022042fd9566e9d7b60c54100cb6e1d4edc985"
+ "90467d0502c17fce69d00ac5efb40b2cb167d8a44ab93d73c4d0f109fb5a26c2"
+ "f8823236ff517cf84412e173679cfae42e043b6fec81f9d984b562517e6febe1"
+ "f72295dbc3fdfc19d3240aa75515563f31dad83563f3a315acf9a0b351a23f02"
+ "03010001",
"3081a1300d06092a864886f70d010101050003818f30818c0284ffffffff00ab"
+ "9014dc47d44b6d260fc1fef9ab022042fd9566e9d7b60c54100cb6e1d4edc985"
+ "90467d0502c17fce69d00ac5efb40b2cb167d8a44ab93d73c4d0f109fb5a26c2"
+ "f8823236ff517cf84412e173679cfae42e043b6fec81f9d984b562517e6febe1"
+ "f72295dbc3fdfc19d3240aa75515563f31dad83563f3a315acf9a0b351a23f02"
+ "03010001",
"3081a2300d06092a864886f70d010101050003819030818d02818100ab9014dc"
+ "47d44b6d260fc1fef9ab022042fd9566e9d7b60c54100cb6e1d4edc98590467d"
+ "0502c17fce69d00ac5efb40b2cb167d8a44ab93d73c4d0f109fb5a26c2f88232"
+ "36ff517cf84412e173679cfae42e043b6fec81f9d984b562517e6febe1f72295"
+ "dbc3fdfc19d3240aa75515563f31dad83563f3a315acf9a0b351a23f0284ffff"
+ "ffff010001",
// length = 2**64 - 1
"3088ffffffffffffffff300d06092a864886f70d010101050003818d00308189"
+ "02818100ab9014dc47d44b6d260fc1fef9ab022042fd9566e9d7b60c54100cb6"
+ "e1d4edc98590467d0502c17fce69d00ac5efb40b2cb167d8a44ab93d73c4d0f1"
+ "09fb5a26c2f8823236ff517cf84412e173679cfae42e043b6fec81f9d984b562"
+ "517e6febe1f72295dbc3fdfc19d3240aa75515563f31dad83563f3a315acf9a0"
+ "b351a23f0203010001",
"3081a73088ffffffffffffffff06092a864886f70d010101050003818d003081"
+ "8902818100ab9014dc47d44b6d260fc1fef9ab022042fd9566e9d7b60c54100c"
+ "b6e1d4edc98590467d0502c17fce69d00ac5efb40b2cb167d8a44ab93d73c4d0"
+ "f109fb5a26c2f8823236ff517cf84412e173679cfae42e043b6fec81f9d984b5"
+ "62517e6febe1f72295dbc3fdfc19d3240aa75515563f31dad83563f3a315acf9"
+ "a0b351a23f0203010001",
"3081a730150688ffffffffffffffff2a864886f70d010101050003818d003081"
+ "8902818100ab9014dc47d44b6d260fc1fef9ab022042fd9566e9d7b60c54100c"
+ "b6e1d4edc98590467d0502c17fce69d00ac5efb40b2cb167d8a44ab93d73c4d0"
+ "f109fb5a26c2f8823236ff517cf84412e173679cfae42e043b6fec81f9d984b5"
+ "62517e6febe1f72295dbc3fdfc19d3240aa75515563f31dad83563f3a315acf9"
+ "a0b351a23f0203010001",
"3081a7301506092a864886f70d0101010588ffffffffffffffff03818d003081"
+ "8902818100ab9014dc47d44b6d260fc1fef9ab022042fd9566e9d7b60c54100c"
+ "b6e1d4edc98590467d0502c17fce69d00ac5efb40b2cb167d8a44ab93d73c4d0"
+ "f109fb5a26c2f8823236ff517cf84412e173679cfae42e043b6fec81f9d984b5"
+ "62517e6febe1f72295dbc3fdfc19d3240aa75515563f31dad83563f3a315acf9"
+ "a0b351a23f0203010001",
"3081a6300d06092a864886f70d01010105000388ffffffffffffffff00308189"
+ "02818100ab9014dc47d44b6d260fc1fef9ab022042fd9566e9d7b60c54100cb6"
+ "e1d4edc98590467d0502c17fce69d00ac5efb40b2cb167d8a44ab93d73c4d0f1"
+ "09fb5a26c2f8823236ff517cf84412e173679cfae42e043b6fec81f9d984b562"
+ "517e6febe1f72295dbc3fdfc19d3240aa75515563f31dad83563f3a315acf9a0"
+ "b351a23f0203010001",
"3081a5300d06092a864886f70d01010105000381933088ffffffffffffffff02"
+ "818100ab9014dc47d44b6d260fc1fef9ab022042fd9566e9d7b60c54100cb6e1"
+ "d4edc98590467d0502c17fce69d00ac5efb40b2cb167d8a44ab93d73c4d0f109"
+ "fb5a26c2f8823236ff517cf84412e173679cfae42e043b6fec81f9d984b56251"
+ "7e6febe1f72295dbc3fdfc19d3240aa75515563f31dad83563f3a315acf9a0b3"
+ "51a23f0203010001",
"3081a5300d06092a864886f70d01010105000381933081900288ffffffffffff"
+ "ffff00ab9014dc47d44b6d260fc1fef9ab022042fd9566e9d7b60c54100cb6e1"
+ "d4edc98590467d0502c17fce69d00ac5efb40b2cb167d8a44ab93d73c4d0f109"
+ "fb5a26c2f8823236ff517cf84412e173679cfae42e043b6fec81f9d984b56251"
+ "7e6febe1f72295dbc3fdfc19d3240aa75515563f31dad83563f3a315acf9a0b3"
+ "51a23f0203010001",
"3081a6300d06092a864886f70d010101050003819430819102818100ab9014dc"
+ "47d44b6d260fc1fef9ab022042fd9566e9d7b60c54100cb6e1d4edc98590467d"
+ "0502c17fce69d00ac5efb40b2cb167d8a44ab93d73c4d0f109fb5a26c2f88232"
+ "36ff517cf84412e173679cfae42e043b6fec81f9d984b562517e6febe1f72295"
+ "dbc3fdfc19d3240aa75515563f31dad83563f3a315acf9a0b351a23f0288ffff"
+ "ffffffffffff010001",
// removing sequence
"",
"30819003818d0030818902818100ab9014dc47d44b6d260fc1fef9ab022042fd"
+ "9566e9d7b60c54100cb6e1d4edc98590467d0502c17fce69d00ac5efb40b2cb1"
+ "67d8a44ab93d73c4d0f109fb5a26c2f8823236ff517cf84412e173679cfae42e"
+ "043b6fec81f9d984b562517e6febe1f72295dbc3fdfc19d3240aa75515563f31"
+ "dad83563f3a315acf9a0b351a23f0203010001",
// appending 0's to sequence
"3081a1300d06092a864886f70d010101050003818d0030818902818100ab9014"
+ "dc47d44b6d260fc1fef9ab022042fd9566e9d7b60c54100cb6e1d4edc9859046"
+ "7d0502c17fce69d00ac5efb40b2cb167d8a44ab93d73c4d0f109fb5a26c2f882"
+ "3236ff517cf84412e173679cfae42e043b6fec81f9d984b562517e6febe1f722"
+ "95dbc3fdfc19d3240aa75515563f31dad83563f3a315acf9a0b351a23f020301"
+ "00010000",
"3081a1300f06092a864886f70d0101010500000003818d0030818902818100ab"
+ "9014dc47d44b6d260fc1fef9ab022042fd9566e9d7b60c54100cb6e1d4edc985"
+ "90467d0502c17fce69d00ac5efb40b2cb167d8a44ab93d73c4d0f109fb5a26c2"
+ "f8823236ff517cf84412e173679cfae42e043b6fec81f9d984b562517e6febe1"
+ "f72295dbc3fdfc19d3240aa75515563f31dad83563f3a315acf9a0b351a23f02"
+ "03010001",
"3081a0300d06092a864886f70d010101050003818e30818b02818100ab9014dc"
+ "47d44b6d260fc1fef9ab022042fd9566e9d7b60c54100cb6e1d4edc98590467d"
+ "0502c17fce69d00ac5efb40b2cb167d8a44ab93d73c4d0f109fb5a26c2f88232"
+ "36ff517cf84412e173679cfae42e043b6fec81f9d984b562517e6febe1f72295"
+ "dbc3fdfc19d3240aa75515563f31dad83563f3a315acf9a0b351a23f02030100"
+ "010000",
// prepending 0's to sequence
"3081a10000300d06092a864886f70d010101050003818d0030818902818100ab"
+ "9014dc47d44b6d260fc1fef9ab022042fd9566e9d7b60c54100cb6e1d4edc985"
+ "90467d0502c17fce69d00ac5efb40b2cb167d8a44ab93d73c4d0f109fb5a26c2"
+ "f8823236ff517cf84412e173679cfae42e043b6fec81f9d984b562517e6febe1"
+ "f72295dbc3fdfc19d3240aa75515563f31dad83563f3a315acf9a0b351a23f02"
+ "03010001",
"3081a1300f000006092a864886f70d010101050003818d0030818902818100ab"
+ "9014dc47d44b6d260fc1fef9ab022042fd9566e9d7b60c54100cb6e1d4edc985"
+ "90467d0502c17fce69d00ac5efb40b2cb167d8a44ab93d73c4d0f109fb5a26c2"
+ "f8823236ff517cf84412e173679cfae42e043b6fec81f9d984b562517e6febe1"
+ "f72295dbc3fdfc19d3240aa75515563f31dad83563f3a315acf9a0b351a23f02"
+ "03010001",
"3081a0300d06092a864886f70d010101050003818e30818b000002818100ab90"
+ "14dc47d44b6d260fc1fef9ab022042fd9566e9d7b60c54100cb6e1d4edc98590"
+ "467d0502c17fce69d00ac5efb40b2cb167d8a44ab93d73c4d0f109fb5a26c2f8"
+ "823236ff517cf84412e173679cfae42e043b6fec81f9d984b562517e6febe1f7"
+ "2295dbc3fdfc19d3240aa75515563f31dad83563f3a315acf9a0b351a23f0203"
+ "010001",
// appending unused 0's
"30819f300d06092a864886f70d010101050003818d0030818902818100ab9014"
+ "dc47d44b6d260fc1fef9ab022042fd9566e9d7b60c54100cb6e1d4edc9859046"
+ "7d0502c17fce69d00ac5efb40b2cb167d8a44ab93d73c4d0f109fb5a26c2f882"
+ "3236ff517cf84412e173679cfae42e043b6fec81f9d984b562517e6febe1f722"
+ "95dbc3fdfc19d3240aa75515563f31dad83563f3a315acf9a0b351a23f020301"
+ "00010000",
"3081a1300d06092a864886f70d0101010500000003818d0030818902818100ab"
+ "9014dc47d44b6d260fc1fef9ab022042fd9566e9d7b60c54100cb6e1d4edc985"
+ "90467d0502c17fce69d00ac5efb40b2cb167d8a44ab93d73c4d0f109fb5a26c2"
+ "f8823236ff517cf84412e173679cfae42e043b6fec81f9d984b562517e6febe1"
+ "f72295dbc3fdfc19d3240aa75515563f31dad83563f3a315acf9a0b351a23f02"
+ "03010001",
"3081a1300f06092a864886f70d0101010000050003818d0030818902818100ab"
+ "9014dc47d44b6d260fc1fef9ab022042fd9566e9d7b60c54100cb6e1d4edc985"
+ "90467d0502c17fce69d00ac5efb40b2cb167d8a44ab93d73c4d0f109fb5a26c2"
+ "f8823236ff517cf84412e173679cfae42e043b6fec81f9d984b562517e6febe1"
+ "f72295dbc3fdfc19d3240aa75515563f31dad83563f3a315acf9a0b351a23f02"
+ "03010001",
"3081a0300d06092a864886f70d010101050003818e30818902818100ab9014dc"
+ "47d44b6d260fc1fef9ab022042fd9566e9d7b60c54100cb6e1d4edc98590467d"
+ "0502c17fce69d00ac5efb40b2cb167d8a44ab93d73c4d0f109fb5a26c2f88232"
+ "36ff517cf84412e173679cfae42e043b6fec81f9d984b562517e6febe1f72295"
+ "dbc3fdfc19d3240aa75515563f31dad83563f3a315acf9a0b351a23f02030100"
+ "010000",
"3081a0300d06092a864886f70d010101050003818e30818b02818100ab9014dc"
+ "47d44b6d260fc1fef9ab022042fd9566e9d7b60c54100cb6e1d4edc98590467d"
+ "0502c17fce69d00ac5efb40b2cb167d8a44ab93d73c4d0f109fb5a26c2f88232"
+ "36ff517cf84412e173679cfae42e043b6fec81f9d984b562517e6febe1f72295"
+ "dbc3fdfc19d3240aa75515563f31dad83563f3a315acf9a0b351a23f00000203"
+ "010001",
// appending null value
"3081a1300d06092a864886f70d010101050003818d0030818902818100ab9014"
+ "dc47d44b6d260fc1fef9ab022042fd9566e9d7b60c54100cb6e1d4edc9859046"
+ "7d0502c17fce69d00ac5efb40b2cb167d8a44ab93d73c4d0f109fb5a26c2f882"
+ "3236ff517cf84412e173679cfae42e043b6fec81f9d984b562517e6febe1f722"
+ "95dbc3fdfc19d3240aa75515563f31dad83563f3a315acf9a0b351a23f020301"
+ "00010500",
"3081a1300f06092a864886f70d0101010500050003818d0030818902818100ab"
+ "9014dc47d44b6d260fc1fef9ab022042fd9566e9d7b60c54100cb6e1d4edc985"
+ "90467d0502c17fce69d00ac5efb40b2cb167d8a44ab93d73c4d0f109fb5a26c2"
+ "f8823236ff517cf84412e173679cfae42e043b6fec81f9d984b562517e6febe1"
+ "f72295dbc3fdfc19d3240aa75515563f31dad83563f3a315acf9a0b351a23f02"
+ "03010001",
"3081a1300f060b2a864886f70d0101010500050003818d0030818902818100ab"
+ "9014dc47d44b6d260fc1fef9ab022042fd9566e9d7b60c54100cb6e1d4edc985"
+ "90467d0502c17fce69d00ac5efb40b2cb167d8a44ab93d73c4d0f109fb5a26c2"
+ "f8823236ff517cf84412e173679cfae42e043b6fec81f9d984b562517e6febe1"
+ "f72295dbc3fdfc19d3240aa75515563f31dad83563f3a315acf9a0b351a23f02"
+ "03010001",
"3081a1300f06092a864886f70d0101010502050003818d0030818902818100ab"
+ "9014dc47d44b6d260fc1fef9ab022042fd9566e9d7b60c54100cb6e1d4edc985"
+ "90467d0502c17fce69d00ac5efb40b2cb167d8a44ab93d73c4d0f109fb5a26c2"
+ "f8823236ff517cf84412e173679cfae42e043b6fec81f9d984b562517e6febe1"
+ "f72295dbc3fdfc19d3240aa75515563f31dad83563f3a315acf9a0b351a23f02"
+ "03010001",
"3081a1300d06092a864886f70d010101050003818f0030818902818100ab9014"
+ "dc47d44b6d260fc1fef9ab022042fd9566e9d7b60c54100cb6e1d4edc9859046"
+ "7d0502c17fce69d00ac5efb40b2cb167d8a44ab93d73c4d0f109fb5a26c2f882"
+ "3236ff517cf84412e173679cfae42e043b6fec81f9d984b562517e6febe1f722"
+ "95dbc3fdfc19d3240aa75515563f31dad83563f3a315acf9a0b351a23f020301"
+ "00010500",
"3081a0300d06092a864886f70d010101050003818e30818b02818100ab9014dc"
+ "47d44b6d260fc1fef9ab022042fd9566e9d7b60c54100cb6e1d4edc98590467d"
+ "0502c17fce69d00ac5efb40b2cb167d8a44ab93d73c4d0f109fb5a26c2f88232"
+ "36ff517cf84412e173679cfae42e043b6fec81f9d984b562517e6febe1f72295"
+ "dbc3fdfc19d3240aa75515563f31dad83563f3a315acf9a0b351a23f02030100"
+ "010500",
"3081a0300d06092a864886f70d010101050003818e30818b02818300ab9014dc"
+ "47d44b6d260fc1fef9ab022042fd9566e9d7b60c54100cb6e1d4edc98590467d"
+ "0502c17fce69d00ac5efb40b2cb167d8a44ab93d73c4d0f109fb5a26c2f88232"
+ "36ff517cf84412e173679cfae42e043b6fec81f9d984b562517e6febe1f72295"
+ "dbc3fdfc19d3240aa75515563f31dad83563f3a315acf9a0b351a23f05000203"
+ "010001",
"3081a0300d06092a864886f70d010101050003818e30818b02818100ab9014dc"
+ "47d44b6d260fc1fef9ab022042fd9566e9d7b60c54100cb6e1d4edc98590467d"
+ "0502c17fce69d00ac5efb40b2cb167d8a44ab93d73c4d0f109fb5a26c2f88232"
+ "36ff517cf84412e173679cfae42e043b6fec81f9d984b562517e6febe1f72295"
+ "dbc3fdfc19d3240aa75515563f31dad83563f3a315acf9a0b351a23f02050100"
+ "010500",
// including garbage
"3081a4498030819f300d06092a864886f70d010101050003818d003081890281"
+ "8100ab9014dc47d44b6d260fc1fef9ab022042fd9566e9d7b60c54100cb6e1d4"
+ "edc98590467d0502c17fce69d00ac5efb40b2cb167d8a44ab93d73c4d0f109fb"
+ "5a26c2f8823236ff517cf84412e173679cfae42e043b6fec81f9d984b562517e"
+ "6febe1f72295dbc3fdfc19d3240aa75515563f31dad83563f3a315acf9a0b351"
+ "a23f0203010001",
"3081a4250030819f300d06092a864886f70d010101050003818d003081890281"
+ "8100ab9014dc47d44b6d260fc1fef9ab022042fd9566e9d7b60c54100cb6e1d4"
+ "edc98590467d0502c17fce69d00ac5efb40b2cb167d8a44ab93d73c4d0f109fb"
+ "5a26c2f8823236ff517cf84412e173679cfae42e043b6fec81f9d984b562517e"
+ "6febe1f72295dbc3fdfc19d3240aa75515563f31dad83563f3a315acf9a0b351"
+ "a23f0203010001",
"3081a230819f300d06092a864886f70d010101050003818d0030818902818100"
+ "ab9014dc47d44b6d260fc1fef9ab022042fd9566e9d7b60c54100cb6e1d4edc9"
+ "8590467d0502c17fce69d00ac5efb40b2cb167d8a44ab93d73c4d0f109fb5a26"
+ "c2f8823236ff517cf84412e173679cfae42e043b6fec81f9d984b562517e6feb"
+ "e1f72295dbc3fdfc19d3240aa75515563f31dad83563f3a315acf9a0b351a23f"
+ "02030100010004deadbeef",
"3081a330114980300d06092a864886f70d010101050003818d00308189028181"
+ "00ab9014dc47d44b6d260fc1fef9ab022042fd9566e9d7b60c54100cb6e1d4ed"
+ "c98590467d0502c17fce69d00ac5efb40b2cb167d8a44ab93d73c4d0f109fb5a"
+ "26c2f8823236ff517cf84412e173679cfae42e043b6fec81f9d984b562517e6f"
+ "ebe1f72295dbc3fdfc19d3240aa75515563f31dad83563f3a315acf9a0b351a2"
+ "3f0203010001",
"3081a330112500300d06092a864886f70d010101050003818d00308189028181"
+ "00ab9014dc47d44b6d260fc1fef9ab022042fd9566e9d7b60c54100cb6e1d4ed"
+ "c98590467d0502c17fce69d00ac5efb40b2cb167d8a44ab93d73c4d0f109fb5a"
+ "26c2f8823236ff517cf84412e173679cfae42e043b6fec81f9d984b562517e6f"
+ "ebe1f72295dbc3fdfc19d3240aa75515563f31dad83563f3a315acf9a0b351a2"
+ "3f0203010001",
"3081a7300f300d06092a864886f70d01010105000004deadbeef03818d003081"
+ "8902818100ab9014dc47d44b6d260fc1fef9ab022042fd9566e9d7b60c54100c"
+ "b6e1d4edc98590467d0502c17fce69d00ac5efb40b2cb167d8a44ab93d73c4d0"
+ "f109fb5a26c2f8823236ff517cf84412e173679cfae42e043b6fec81f9d984b5"
+ "62517e6febe1f72295dbc3fdfc19d3240aa75515563f31dad83563f3a315acf9"
+ "a0b351a23f0203010001",
"3081a33011260d498006092a864886f70d010101050003818d00308189028181"
+ "00ab9014dc47d44b6d260fc1fef9ab022042fd9566e9d7b60c54100cb6e1d4ed"
+ "c98590467d0502c17fce69d00ac5efb40b2cb167d8a44ab93d73c4d0f109fb5a"
+ "26c2f8823236ff517cf84412e173679cfae42e043b6fec81f9d984b562517e6f"
+ "ebe1f72295dbc3fdfc19d3240aa75515563f31dad83563f3a315acf9a0b351a2"
+ "3f0203010001",
"3081a33011260d250006092a864886f70d010101050003818d00308189028181"
+ "00ab9014dc47d44b6d260fc1fef9ab022042fd9566e9d7b60c54100cb6e1d4ed"
+ "c98590467d0502c17fce69d00ac5efb40b2cb167d8a44ab93d73c4d0f109fb5a"
+ "26c2f8823236ff517cf84412e173679cfae42e043b6fec81f9d984b562517e6f"
+ "ebe1f72295dbc3fdfc19d3240aa75515563f31dad83563f3a315acf9a0b351a2"
+ "3f0203010001",
"3081a73015260b06092a864886f70d0101010004deadbeef050003818d003081"
+ "8902818100ab9014dc47d44b6d260fc1fef9ab022042fd9566e9d7b60c54100c"
+ "b6e1d4edc98590467d0502c17fce69d00ac5efb40b2cb167d8a44ab93d73c4d0"
+ "f109fb5a26c2f8823236ff517cf84412e173679cfae42e043b6fec81f9d984b5"
+ "62517e6febe1f72295dbc3fdfc19d3240aa75515563f31dad83563f3a315acf9"
+ "a0b351a23f0203010001",
"3081a3301106092a864886f70d01010125044980050003818d00308189028181"
+ "00ab9014dc47d44b6d260fc1fef9ab022042fd9566e9d7b60c54100cb6e1d4ed"
+ "c98590467d0502c17fce69d00ac5efb40b2cb167d8a44ab93d73c4d0f109fb5a"
+ "26c2f8823236ff517cf84412e173679cfae42e043b6fec81f9d984b562517e6f"
+ "ebe1f72295dbc3fdfc19d3240aa75515563f31dad83563f3a315acf9a0b351a2"
+ "3f0203010001",
"3081a3301106092a864886f70d01010125042500050003818d00308189028181"
+ "00ab9014dc47d44b6d260fc1fef9ab022042fd9566e9d7b60c54100cb6e1d4ed"
+ "c98590467d0502c17fce69d00ac5efb40b2cb167d8a44ab93d73c4d0f109fb5a"
+ "26c2f8823236ff517cf84412e173679cfae42e043b6fec81f9d984b562517e6f"
+ "ebe1f72295dbc3fdfc19d3240aa75515563f31dad83563f3a315acf9a0b351a2"
+ "3f0203010001",
"3081a7301506092a864886f70d010101250205000004deadbeef03818d003081"
+ "8902818100ab9014dc47d44b6d260fc1fef9ab022042fd9566e9d7b60c54100c"
+ "b6e1d4edc98590467d0502c17fce69d00ac5efb40b2cb167d8a44ab93d73c4d0"
+ "f109fb5a26c2f8823236ff517cf84412e173679cfae42e043b6fec81f9d984b5"
+ "62517e6febe1f72295dbc3fdfc19d3240aa75515563f31dad83563f3a315acf9"
+ "a0b351a23f0203010001",
"3081a4300d06092a864886f70d0101010500238192498003818d003081890281"
+ "8100ab9014dc47d44b6d260fc1fef9ab022042fd9566e9d7b60c54100cb6e1d4"
+ "edc98590467d0502c17fce69d00ac5efb40b2cb167d8a44ab93d73c4d0f109fb"
+ "5a26c2f8823236ff517cf84412e173679cfae42e043b6fec81f9d984b562517e"
+ "6febe1f72295dbc3fdfc19d3240aa75515563f31dad83563f3a315acf9a0b351"
+ "a23f0203010001",
"3081a4300d06092a864886f70d0101010500238192250003818d003081890281"
+ "8100ab9014dc47d44b6d260fc1fef9ab022042fd9566e9d7b60c54100cb6e1d4"
+ "edc98590467d0502c17fce69d00ac5efb40b2cb167d8a44ab93d73c4d0f109fb"
+ "5a26c2f8823236ff517cf84412e173679cfae42e043b6fec81f9d984b562517e"
+ "6febe1f72295dbc3fdfc19d3240aa75515563f31dad83563f3a315acf9a0b351"
+ "a23f0203010001",
"3081a8300d06092a864886f70d010101050023819003818d0030818902818100"
+ "ab9014dc47d44b6d260fc1fef9ab022042fd9566e9d7b60c54100cb6e1d4edc9"
+ "8590467d0502c17fce69d00ac5efb40b2cb167d8a44ab93d73c4d0f109fb5a26"
+ "c2f8823236ff517cf84412e173679cfae42e043b6fec81f9d984b562517e6feb"
+ "e1f72295dbc3fdfc19d3240aa75515563f31dad83563f3a315acf9a0b351a23f"
+ "02030100010004deadbeef",
"3081a3300d06092a864886f70d010101050003819130818e4980308189028181"
+ "00ab9014dc47d44b6d260fc1fef9ab022042fd9566e9d7b60c54100cb6e1d4ed"
+ "c98590467d0502c17fce69d00ac5efb40b2cb167d8a44ab93d73c4d0f109fb5a"
+ "26c2f8823236ff517cf84412e173679cfae42e043b6fec81f9d984b562517e6f"
+ "ebe1f72295dbc3fdfc19d3240aa75515563f31dad83563f3a315acf9a0b351a2"
+ "3f0203010001",
"3081a3300d06092a864886f70d010101050003819130818e2500308189028181"
+ "00ab9014dc47d44b6d260fc1fef9ab022042fd9566e9d7b60c54100cb6e1d4ed"
+ "c98590467d0502c17fce69d00ac5efb40b2cb167d8a44ab93d73c4d0f109fb5a"
+ "26c2f8823236ff517cf84412e173679cfae42e043b6fec81f9d984b562517e6f"
+ "ebe1f72295dbc3fdfc19d3240aa75515563f31dad83563f3a315acf9a0b351a2"
+ "3f0203010001",
"3081a7300d06092a864886f70d010101050003819530818c30818902818100ab"
+ "9014dc47d44b6d260fc1fef9ab022042fd9566e9d7b60c54100cb6e1d4edc985"
+ "90467d0502c17fce69d00ac5efb40b2cb167d8a44ab93d73c4d0f109fb5a26c2"
+ "f8823236ff517cf84412e173679cfae42e043b6fec81f9d984b562517e6febe1"
+ "f72295dbc3fdfc19d3240aa75515563f31dad83563f3a315acf9a0b351a23f02"
+ "030100010004deadbeef",
"3081a3300d06092a864886f70d010101050003819130818e2281864980028181"
+ "00ab9014dc47d44b6d260fc1fef9ab022042fd9566e9d7b60c54100cb6e1d4ed"
+ "c98590467d0502c17fce69d00ac5efb40b2cb167d8a44ab93d73c4d0f109fb5a"
+ "26c2f8823236ff517cf84412e173679cfae42e043b6fec81f9d984b562517e6f"
+ "ebe1f72295dbc3fdfc19d3240aa75515563f31dad83563f3a315acf9a0b351a2"
+ "3f0203010001",
"3081a3300d06092a864886f70d010101050003819130818e2281862500028181"
+ "00ab9014dc47d44b6d260fc1fef9ab022042fd9566e9d7b60c54100cb6e1d4ed"
+ "c98590467d0502c17fce69d00ac5efb40b2cb167d8a44ab93d73c4d0f109fb5a"
+ "26c2f8823236ff517cf84412e173679cfae42e043b6fec81f9d984b562517e6f"
+ "ebe1f72295dbc3fdfc19d3240aa75515563f31dad83563f3a315acf9a0b351a2"
+ "3f0203010001",
"3081a7300d06092a864886f70d010101050003819530819222818402818100ab"
+ "9014dc47d44b6d260fc1fef9ab022042fd9566e9d7b60c54100cb6e1d4edc985"
+ "90467d0502c17fce69d00ac5efb40b2cb167d8a44ab93d73c4d0f109fb5a26c2"
+ "f8823236ff517cf84412e173679cfae42e043b6fec81f9d984b562517e6febe1"
+ "f72295dbc3fdfc19d3240aa75515563f31dad83563f3a315acf9a0b351a23f00"
+ "04deadbeef0203010001",
"3081a2300d06092a864886f70d010101050003819030818d02818100ab9014dc"
+ "47d44b6d260fc1fef9ab022042fd9566e9d7b60c54100cb6e1d4edc98590467d"
+ "0502c17fce69d00ac5efb40b2cb167d8a44ab93d73c4d0f109fb5a26c2f88232"
+ "36ff517cf84412e173679cfae42e043b6fec81f9d984b562517e6febe1f72295"
+ "dbc3fdfc19d3240aa75515563f31dad83563f3a315acf9a0b351a23f22074980"
+ "0203010001",
"3081a2300d06092a864886f70d010101050003819030818d02818100ab9014dc"
+ "47d44b6d260fc1fef9ab022042fd9566e9d7b60c54100cb6e1d4edc98590467d"
+ "0502c17fce69d00ac5efb40b2cb167d8a44ab93d73c4d0f109fb5a26c2f88232"
+ "36ff517cf84412e173679cfae42e043b6fec81f9d984b562517e6febe1f72295"
+ "dbc3fdfc19d3240aa75515563f31dad83563f3a315acf9a0b351a23f22072500"
+ "0203010001",
"3081a6300d06092a864886f70d010101050003819430819102818100ab9014dc"
+ "47d44b6d260fc1fef9ab022042fd9566e9d7b60c54100cb6e1d4edc98590467d"
+ "0502c17fce69d00ac5efb40b2cb167d8a44ab93d73c4d0f109fb5a26c2f88232"
+ "36ff517cf84412e173679cfae42e043b6fec81f9d984b562517e6febe1f72295"
+ "dbc3fdfc19d3240aa75515563f31dad83563f3a315acf9a0b351a23f22050203"
+ "0100010004deadbeef",
// including undefined tags
"3081a8aa00bb00cd0030819f300d06092a864886f70d010101050003818d0030"
+ "818902818100ab9014dc47d44b6d260fc1fef9ab022042fd9566e9d7b60c5410"
+ "0cb6e1d4edc98590467d0502c17fce69d00ac5efb40b2cb167d8a44ab93d73c4"
+ "d0f109fb5a26c2f8823236ff517cf84412e173679cfae42e043b6fec81f9d984"
+ "b562517e6febe1f72295dbc3fdfc19d3240aa75515563f31dad83563f3a315ac"
+ "f9a0b351a23f0203010001",
"3081a6aa02aabb30819f300d06092a864886f70d010101050003818d00308189"
+ "02818100ab9014dc47d44b6d260fc1fef9ab022042fd9566e9d7b60c54100cb6"
+ "e1d4edc98590467d0502c17fce69d00ac5efb40b2cb167d8a44ab93d73c4d0f1"
+ "09fb5a26c2f8823236ff517cf84412e173679cfae42e043b6fec81f9d984b562"
+ "517e6febe1f72295dbc3fdfc19d3240aa75515563f31dad83563f3a315acf9a0"
+ "b351a23f0203010001",
"3081a73015aa00bb00cd00300d06092a864886f70d010101050003818d003081"
+ "8902818100ab9014dc47d44b6d260fc1fef9ab022042fd9566e9d7b60c54100c"
+ "b6e1d4edc98590467d0502c17fce69d00ac5efb40b2cb167d8a44ab93d73c4d0"
+ "f109fb5a26c2f8823236ff517cf84412e173679cfae42e043b6fec81f9d984b5"
+ "62517e6febe1f72295dbc3fdfc19d3240aa75515563f31dad83563f3a315acf9"
+ "a0b351a23f0203010001",
"3081a53013aa02aabb300d06092a864886f70d010101050003818d0030818902"
+ "818100ab9014dc47d44b6d260fc1fef9ab022042fd9566e9d7b60c54100cb6e1"
+ "d4edc98590467d0502c17fce69d00ac5efb40b2cb167d8a44ab93d73c4d0f109"
+ "fb5a26c2f8823236ff517cf84412e173679cfae42e043b6fec81f9d984b56251"
+ "7e6febe1f72295dbc3fdfc19d3240aa75515563f31dad83563f3a315acf9a0b3"
+ "51a23f0203010001",
"3081a730152611aa00bb00cd0006092a864886f70d010101050003818d003081"
+ "8902818100ab9014dc47d44b6d260fc1fef9ab022042fd9566e9d7b60c54100c"
+ "b6e1d4edc98590467d0502c17fce69d00ac5efb40b2cb167d8a44ab93d73c4d0"
+ "f109fb5a26c2f8823236ff517cf84412e173679cfae42e043b6fec81f9d984b5"
+ "62517e6febe1f72295dbc3fdfc19d3240aa75515563f31dad83563f3a315acf9"
+ "a0b351a23f0203010001",
"3081a53013260faa02aabb06092a864886f70d010101050003818d0030818902"
+ "818100ab9014dc47d44b6d260fc1fef9ab022042fd9566e9d7b60c54100cb6e1"
+ "d4edc98590467d0502c17fce69d00ac5efb40b2cb167d8a44ab93d73c4d0f109"
+ "fb5a26c2f8823236ff517cf84412e173679cfae42e043b6fec81f9d984b56251"
+ "7e6febe1f72295dbc3fdfc19d3240aa75515563f31dad83563f3a315acf9a0b3"
+ "51a23f0203010001",
"3081a7301506092a864886f70d0101012508aa00bb00cd00050003818d003081"
+ "8902818100ab9014dc47d44b6d260fc1fef9ab022042fd9566e9d7b60c54100c"
+ "b6e1d4edc98590467d0502c17fce69d00ac5efb40b2cb167d8a44ab93d73c4d0"
+ "f109fb5a26c2f8823236ff517cf84412e173679cfae42e043b6fec81f9d984b5"
+ "62517e6febe1f72295dbc3fdfc19d3240aa75515563f31dad83563f3a315acf9"
+ "a0b351a23f0203010001",
"3081a5301306092a864886f70d0101012506aa02aabb050003818d0030818902"
+ "818100ab9014dc47d44b6d260fc1fef9ab022042fd9566e9d7b60c54100cb6e1"
+ "d4edc98590467d0502c17fce69d00ac5efb40b2cb167d8a44ab93d73c4d0f109"
+ "fb5a26c2f8823236ff517cf84412e173679cfae42e043b6fec81f9d984b56251"
+ "7e6febe1f72295dbc3fdfc19d3240aa75515563f31dad83563f3a315acf9a0b3"
+ "51a23f0203010001",
"3081a8300d06092a864886f70d0101010500238196aa00bb00cd0003818d0030"
+ "818902818100ab9014dc47d44b6d260fc1fef9ab022042fd9566e9d7b60c5410"
+ "0cb6e1d4edc98590467d0502c17fce69d00ac5efb40b2cb167d8a44ab93d73c4"
+ "d0f109fb5a26c2f8823236ff517cf84412e173679cfae42e043b6fec81f9d984"
+ "b562517e6febe1f72295dbc3fdfc19d3240aa75515563f31dad83563f3a315ac"
+ "f9a0b351a23f0203010001",
"3081a6300d06092a864886f70d0101010500238194aa02aabb03818d00308189"
+ "02818100ab9014dc47d44b6d260fc1fef9ab022042fd9566e9d7b60c54100cb6"
+ "e1d4edc98590467d0502c17fce69d00ac5efb40b2cb167d8a44ab93d73c4d0f1"
+ "09fb5a26c2f8823236ff517cf84412e173679cfae42e043b6fec81f9d984b562"
+ "517e6febe1f72295dbc3fdfc19d3240aa75515563f31dad83563f3a315acf9a0"
+ "b351a23f0203010001",
"3081a7300d06092a864886f70d0101010500038195308192aa00bb00cd003081"
+ "8902818100ab9014dc47d44b6d260fc1fef9ab022042fd9566e9d7b60c54100c"
+ "b6e1d4edc98590467d0502c17fce69d00ac5efb40b2cb167d8a44ab93d73c4d0"
+ "f109fb5a26c2f8823236ff517cf84412e173679cfae42e043b6fec81f9d984b5"
+ "62517e6febe1f72295dbc3fdfc19d3240aa75515563f31dad83563f3a315acf9"
+ "a0b351a23f0203010001",
"3081a5300d06092a864886f70d0101010500038193308190aa02aabb30818902"
+ "818100ab9014dc47d44b6d260fc1fef9ab022042fd9566e9d7b60c54100cb6e1"
+ "d4edc98590467d0502c17fce69d00ac5efb40b2cb167d8a44ab93d73c4d0f109"
+ "fb5a26c2f8823236ff517cf84412e173679cfae42e043b6fec81f9d984b56251"
+ "7e6febe1f72295dbc3fdfc19d3240aa75515563f31dad83563f3a315acf9a0b3"
+ "51a23f0203010001",
"3081a7300d06092a864886f70d010101050003819530819222818aaa00bb00cd"
+ "0002818100ab9014dc47d44b6d260fc1fef9ab022042fd9566e9d7b60c54100c"
+ "b6e1d4edc98590467d0502c17fce69d00ac5efb40b2cb167d8a44ab93d73c4d0"
+ "f109fb5a26c2f8823236ff517cf84412e173679cfae42e043b6fec81f9d984b5"
+ "62517e6febe1f72295dbc3fdfc19d3240aa75515563f31dad83563f3a315acf9"
+ "a0b351a23f0203010001",
"3081a5300d06092a864886f70d0101010500038193308190228188aa02aabb02"
+ "818100ab9014dc47d44b6d260fc1fef9ab022042fd9566e9d7b60c54100cb6e1"
+ "d4edc98590467d0502c17fce69d00ac5efb40b2cb167d8a44ab93d73c4d0f109"
+ "fb5a26c2f8823236ff517cf84412e173679cfae42e043b6fec81f9d984b56251"
+ "7e6febe1f72295dbc3fdfc19d3240aa75515563f31dad83563f3a315acf9a0b3"
+ "51a23f0203010001",
"3081a6300d06092a864886f70d010101050003819430819102818100ab9014dc"
+ "47d44b6d260fc1fef9ab022042fd9566e9d7b60c54100cb6e1d4edc98590467d"
+ "0502c17fce69d00ac5efb40b2cb167d8a44ab93d73c4d0f109fb5a26c2f88232"
+ "36ff517cf84412e173679cfae42e043b6fec81f9d984b562517e6febe1f72295"
+ "dbc3fdfc19d3240aa75515563f31dad83563f3a315acf9a0b351a23f220baa00"
+ "bb00cd000203010001",
"3081a4300d06092a864886f70d010101050003819230818f02818100ab9014dc"
+ "47d44b6d260fc1fef9ab022042fd9566e9d7b60c54100cb6e1d4edc98590467d"
+ "0502c17fce69d00ac5efb40b2cb167d8a44ab93d73c4d0f109fb5a26c2f88232"
+ "36ff517cf84412e173679cfae42e043b6fec81f9d984b562517e6febe1f72295"
+ "dbc3fdfc19d3240aa75515563f31dad83563f3a315acf9a0b351a23f2209aa02"
+ "aabb0203010001",
// changing tag value
"2e819f300d06092a864886f70d010101050003818d0030818902818100ab9014"
+ "dc47d44b6d260fc1fef9ab022042fd9566e9d7b60c54100cb6e1d4edc9859046"
+ "7d0502c17fce69d00ac5efb40b2cb167d8a44ab93d73c4d0f109fb5a26c2f882"
+ "3236ff517cf84412e173679cfae42e043b6fec81f9d984b562517e6febe1f722"
+ "95dbc3fdfc19d3240aa75515563f31dad83563f3a315acf9a0b351a23f020301"
+ "0001",
"32819f300d06092a864886f70d010101050003818d0030818902818100ab9014"
+ "dc47d44b6d260fc1fef9ab022042fd9566e9d7b60c54100cb6e1d4edc9859046"
+ "7d0502c17fce69d00ac5efb40b2cb167d8a44ab93d73c4d0f109fb5a26c2f882"
+ "3236ff517cf84412e173679cfae42e043b6fec81f9d984b562517e6febe1f722"
+ "95dbc3fdfc19d3240aa75515563f31dad83563f3a315acf9a0b351a23f020301"
+ "0001",
"ff819f300d06092a864886f70d010101050003818d0030818902818100ab9014"
+ "dc47d44b6d260fc1fef9ab022042fd9566e9d7b60c54100cb6e1d4edc9859046"
+ "7d0502c17fce69d00ac5efb40b2cb167d8a44ab93d73c4d0f109fb5a26c2f882"
+ "3236ff517cf84412e173679cfae42e043b6fec81f9d984b562517e6febe1f722"
+ "95dbc3fdfc19d3240aa75515563f31dad83563f3a315acf9a0b351a23f020301"
+ "0001",
"30819f2e0d06092a864886f70d010101050003818d0030818902818100ab9014"
+ "dc47d44b6d260fc1fef9ab022042fd9566e9d7b60c54100cb6e1d4edc9859046"
+ "7d0502c17fce69d00ac5efb40b2cb167d8a44ab93d73c4d0f109fb5a26c2f882"
+ "3236ff517cf84412e173679cfae42e043b6fec81f9d984b562517e6febe1f722"
+ "95dbc3fdfc19d3240aa75515563f31dad83563f3a315acf9a0b351a23f020301"
+ "0001",
"30819f320d06092a864886f70d010101050003818d0030818902818100ab9014"
+ "dc47d44b6d260fc1fef9ab022042fd9566e9d7b60c54100cb6e1d4edc9859046"
+ "7d0502c17fce69d00ac5efb40b2cb167d8a44ab93d73c4d0f109fb5a26c2f882"
+ "3236ff517cf84412e173679cfae42e043b6fec81f9d984b562517e6febe1f722"
+ "95dbc3fdfc19d3240aa75515563f31dad83563f3a315acf9a0b351a23f020301"
+ "0001",
"30819fff0d06092a864886f70d010101050003818d0030818902818100ab9014"
+ "dc47d44b6d260fc1fef9ab022042fd9566e9d7b60c54100cb6e1d4edc9859046"
+ "7d0502c17fce69d00ac5efb40b2cb167d8a44ab93d73c4d0f109fb5a26c2f882"
+ "3236ff517cf84412e173679cfae42e043b6fec81f9d984b562517e6febe1f722"
+ "95dbc3fdfc19d3240aa75515563f31dad83563f3a315acf9a0b351a23f020301"
+ "0001",
"30819f300d04092a864886f70d010101050003818d0030818902818100ab9014"
+ "dc47d44b6d260fc1fef9ab022042fd9566e9d7b60c54100cb6e1d4edc9859046"
+ "7d0502c17fce69d00ac5efb40b2cb167d8a44ab93d73c4d0f109fb5a26c2f882"
+ "3236ff517cf84412e173679cfae42e043b6fec81f9d984b562517e6febe1f722"
+ "95dbc3fdfc19d3240aa75515563f31dad83563f3a315acf9a0b351a23f020301"
+ "0001",
"30819f300d08092a864886f70d010101050003818d0030818902818100ab9014"
+ "dc47d44b6d260fc1fef9ab022042fd9566e9d7b60c54100cb6e1d4edc9859046"
+ "7d0502c17fce69d00ac5efb40b2cb167d8a44ab93d73c4d0f109fb5a26c2f882"
+ "3236ff517cf84412e173679cfae42e043b6fec81f9d984b562517e6febe1f722"
+ "95dbc3fdfc19d3240aa75515563f31dad83563f3a315acf9a0b351a23f020301"
+ "0001",
"30819f300dff092a864886f70d010101050003818d0030818902818100ab9014"
+ "dc47d44b6d260fc1fef9ab022042fd9566e9d7b60c54100cb6e1d4edc9859046"
+ "7d0502c17fce69d00ac5efb40b2cb167d8a44ab93d73c4d0f109fb5a26c2f882"
+ "3236ff517cf84412e173679cfae42e043b6fec81f9d984b562517e6febe1f722"
+ "95dbc3fdfc19d3240aa75515563f31dad83563f3a315acf9a0b351a23f020301"
+ "0001",
"30819f300d06092a864886f70d010101030003818d0030818902818100ab9014"
+ "dc47d44b6d260fc1fef9ab022042fd9566e9d7b60c54100cb6e1d4edc9859046"
+ "7d0502c17fce69d00ac5efb40b2cb167d8a44ab93d73c4d0f109fb5a26c2f882"
+ "3236ff517cf84412e173679cfae42e043b6fec81f9d984b562517e6febe1f722"
+ "95dbc3fdfc19d3240aa75515563f31dad83563f3a315acf9a0b351a23f020301"
+ "0001",
"30819f300d06092a864886f70d010101070003818d0030818902818100ab9014"
+ "dc47d44b6d260fc1fef9ab022042fd9566e9d7b60c54100cb6e1d4edc9859046"
+ "7d0502c17fce69d00ac5efb40b2cb167d8a44ab93d73c4d0f109fb5a26c2f882"
+ "3236ff517cf84412e173679cfae42e043b6fec81f9d984b562517e6febe1f722"
+ "95dbc3fdfc19d3240aa75515563f31dad83563f3a315acf9a0b351a23f020301"
+ "0001",
"30819f300d06092a864886f70d010101ff0003818d0030818902818100ab9014"
+ "dc47d44b6d260fc1fef9ab022042fd9566e9d7b60c54100cb6e1d4edc9859046"
+ "7d0502c17fce69d00ac5efb40b2cb167d8a44ab93d73c4d0f109fb5a26c2f882"
+ "3236ff517cf84412e173679cfae42e043b6fec81f9d984b562517e6febe1f722"
+ "95dbc3fdfc19d3240aa75515563f31dad83563f3a315acf9a0b351a23f020301"
+ "0001",
"30819f300d06092a864886f70d010101050001818d0030818902818100ab9014"
+ "dc47d44b6d260fc1fef9ab022042fd9566e9d7b60c54100cb6e1d4edc9859046"
+ "7d0502c17fce69d00ac5efb40b2cb167d8a44ab93d73c4d0f109fb5a26c2f882"
+ "3236ff517cf84412e173679cfae42e043b6fec81f9d984b562517e6febe1f722"
+ "95dbc3fdfc19d3240aa75515563f31dad83563f3a315acf9a0b351a23f020301"
+ "0001",
"30819f300d06092a864886f70d010101050005818d0030818902818100ab9014"
+ "dc47d44b6d260fc1fef9ab022042fd9566e9d7b60c54100cb6e1d4edc9859046"
+ "7d0502c17fce69d00ac5efb40b2cb167d8a44ab93d73c4d0f109fb5a26c2f882"
+ "3236ff517cf84412e173679cfae42e043b6fec81f9d984b562517e6febe1f722"
+ "95dbc3fdfc19d3240aa75515563f31dad83563f3a315acf9a0b351a23f020301"
+ "0001",
"30819f300d06092a864886f70d0101010500ff818d0030818902818100ab9014"
+ "dc47d44b6d260fc1fef9ab022042fd9566e9d7b60c54100cb6e1d4edc9859046"
+ "7d0502c17fce69d00ac5efb40b2cb167d8a44ab93d73c4d0f109fb5a26c2f882"
+ "3236ff517cf84412e173679cfae42e043b6fec81f9d984b562517e6febe1f722"
+ "95dbc3fdfc19d3240aa75515563f31dad83563f3a315acf9a0b351a23f020301"
+ "0001",
"30819e300d06092a864886f70d010101050003818c2e818902818100ab9014dc"
+ "47d44b6d260fc1fef9ab022042fd9566e9d7b60c54100cb6e1d4edc98590467d"
+ "0502c17fce69d00ac5efb40b2cb167d8a44ab93d73c4d0f109fb5a26c2f88232"
+ "36ff517cf84412e173679cfae42e043b6fec81f9d984b562517e6febe1f72295"
+ "dbc3fdfc19d3240aa75515563f31dad83563f3a315acf9a0b351a23f02030100"
+ "01",
"30819e300d06092a864886f70d010101050003818c32818902818100ab9014dc"
+ "47d44b6d260fc1fef9ab022042fd9566e9d7b60c54100cb6e1d4edc98590467d"
+ "0502c17fce69d00ac5efb40b2cb167d8a44ab93d73c4d0f109fb5a26c2f88232"
+ "36ff517cf84412e173679cfae42e043b6fec81f9d984b562517e6febe1f72295"
+ "dbc3fdfc19d3240aa75515563f31dad83563f3a315acf9a0b351a23f02030100"
+ "01",
"30819e300d06092a864886f70d010101050003818cff818902818100ab9014dc"
+ "47d44b6d260fc1fef9ab022042fd9566e9d7b60c54100cb6e1d4edc98590467d"
+ "0502c17fce69d00ac5efb40b2cb167d8a44ab93d73c4d0f109fb5a26c2f88232"
+ "36ff517cf84412e173679cfae42e043b6fec81f9d984b562517e6febe1f72295"
+ "dbc3fdfc19d3240aa75515563f31dad83563f3a315acf9a0b351a23f02030100"
+ "01",
"30819e300d06092a864886f70d010101050003818c30818900818100ab9014dc"
+ "47d44b6d260fc1fef9ab022042fd9566e9d7b60c54100cb6e1d4edc98590467d"
+ "0502c17fce69d00ac5efb40b2cb167d8a44ab93d73c4d0f109fb5a26c2f88232"
+ "36ff517cf84412e173679cfae42e043b6fec81f9d984b562517e6febe1f72295"
+ "dbc3fdfc19d3240aa75515563f31dad83563f3a315acf9a0b351a23f02030100"
+ "01",
"30819e300d06092a864886f70d010101050003818c30818904818100ab9014dc"
+ "47d44b6d260fc1fef9ab022042fd9566e9d7b60c54100cb6e1d4edc98590467d"
+ "0502c17fce69d00ac5efb40b2cb167d8a44ab93d73c4d0f109fb5a26c2f88232"
+ "36ff517cf84412e173679cfae42e043b6fec81f9d984b562517e6febe1f72295"
+ "dbc3fdfc19d3240aa75515563f31dad83563f3a315acf9a0b351a23f02030100"
+ "01",
"30819e300d06092a864886f70d010101050003818c308189ff818100ab9014dc"
+ "47d44b6d260fc1fef9ab022042fd9566e9d7b60c54100cb6e1d4edc98590467d"
+ "0502c17fce69d00ac5efb40b2cb167d8a44ab93d73c4d0f109fb5a26c2f88232"
+ "36ff517cf84412e173679cfae42e043b6fec81f9d984b562517e6febe1f72295"
+ "dbc3fdfc19d3240aa75515563f31dad83563f3a315acf9a0b351a23f02030100"
+ "01",
"30819e300d06092a864886f70d010101050003818c30818902818100ab9014dc"
+ "47d44b6d260fc1fef9ab022042fd9566e9d7b60c54100cb6e1d4edc98590467d"
+ "0502c17fce69d00ac5efb40b2cb167d8a44ab93d73c4d0f109fb5a26c2f88232"
+ "36ff517cf84412e173679cfae42e043b6fec81f9d984b562517e6febe1f72295"
+ "dbc3fdfc19d3240aa75515563f31dad83563f3a315acf9a0b351a23f00030100"
+ "01",
"30819e300d06092a864886f70d010101050003818c30818902818100ab9014dc"
+ "47d44b6d260fc1fef9ab022042fd9566e9d7b60c54100cb6e1d4edc98590467d"
+ "0502c17fce69d00ac5efb40b2cb167d8a44ab93d73c4d0f109fb5a26c2f88232"
+ "36ff517cf84412e173679cfae42e043b6fec81f9d984b562517e6febe1f72295"
+ "dbc3fdfc19d3240aa75515563f31dad83563f3a315acf9a0b351a23f04030100"
+ "01",
"30819e300d06092a864886f70d010101050003818c30818902818100ab9014dc"
+ "47d44b6d260fc1fef9ab022042fd9566e9d7b60c54100cb6e1d4edc98590467d"
+ "0502c17fce69d00ac5efb40b2cb167d8a44ab93d73c4d0f109fb5a26c2f88232"
+ "36ff517cf84412e173679cfae42e043b6fec81f9d984b562517e6febe1f72295"
+ "dbc3fdfc19d3240aa75515563f31dad83563f3a315acf9a0b351a23fff030100"
+ "01",
// dropping value of sequence
"3000",
"308192300003818d0030818902818100ab9014dc47d44b6d260fc1fef9ab0220"
+ "42fd9566e9d7b60c54100cb6e1d4edc98590467d0502c17fce69d00ac5efb40b"
+ "2cb167d8a44ab93d73c4d0f109fb5a26c2f8823236ff517cf84412e173679cfa"
+ "e42e043b6fec81f9d984b562517e6febe1f72295dbc3fdfc19d3240aa7551556"
+ "3f31dad83563f3a315acf9a0b351a23f0203010001",
// using composition
"3081a430013030819e0d06092a864886f70d010101050003818d003081890281"
+ "8100ab9014dc47d44b6d260fc1fef9ab022042fd9566e9d7b60c54100cb6e1d4"
+ "edc98590467d0502c17fce69d00ac5efb40b2cb167d8a44ab93d73c4d0f109fb"
+ "5a26c2f8823236ff517cf84412e173679cfae42e043b6fec81f9d984b562517e"
+ "6febe1f72295dbc3fdfc19d3240aa75515563f31dad83563f3a315acf9a0b351"
+ "a23f0203010001",
"3081a33011300106300c092a864886f70d010101050003818d00308189028181"
+ "00ab9014dc47d44b6d260fc1fef9ab022042fd9566e9d7b60c54100cb6e1d4ed"
+ "c98590467d0502c17fce69d00ac5efb40b2cb167d8a44ab93d73c4d0f109fb5a"
+ "26c2f8823236ff517cf84412e173679cfae42e043b6fec81f9d984b562517e6f"
+ "ebe1f72295dbc3fdfc19d3240aa75515563f31dad83563f3a315acf9a0b351a2"
+ "3f0203010001",
"3081a33011260d06012a0608864886f70d010101050003818d00308189028181"
+ "00ab9014dc47d44b6d260fc1fef9ab022042fd9566e9d7b60c54100cb6e1d4ed"
+ "c98590467d0502c17fce69d00ac5efb40b2cb167d8a44ab93d73c4d0f109fb5a"
+ "26c2f8823236ff517cf84412e173679cfae42e043b6fec81f9d984b562517e6f"
+ "ebe1f72295dbc3fdfc19d3240aa75515563f31dad83563f3a315acf9a0b351a2"
+ "3f0203010001",
"3081a4300d06092a864886f70d010101050023819203010003818c3081890281"
+ "8100ab9014dc47d44b6d260fc1fef9ab022042fd9566e9d7b60c54100cb6e1d4"
+ "edc98590467d0502c17fce69d00ac5efb40b2cb167d8a44ab93d73c4d0f109fb"
+ "5a26c2f8823236ff517cf84412e173679cfae42e043b6fec81f9d984b562517e"
+ "6febe1f72295dbc3fdfc19d3240aa75515563f31dad83563f3a315acf9a0b351"
+ "a23f0203010001",
"3081a3300d06092a864886f70d010101050003819130818e3001023081888181"
+ "00ab9014dc47d44b6d260fc1fef9ab022042fd9566e9d7b60c54100cb6e1d4ed"
+ "c98590467d0502c17fce69d00ac5efb40b2cb167d8a44ab93d73c4d0f109fb5a"
+ "26c2f8823236ff517cf84412e173679cfae42e043b6fec81f9d984b562517e6f"
+ "ebe1f72295dbc3fdfc19d3240aa75515563f31dad83563f3a315acf9a0b351a2"
+ "3f0203010001",
"3081a3300d06092a864886f70d010101050003819130818e2281860201000281"
+ "80ab9014dc47d44b6d260fc1fef9ab022042fd9566e9d7b60c54100cb6e1d4ed"
+ "c98590467d0502c17fce69d00ac5efb40b2cb167d8a44ab93d73c4d0f109fb5a"
+ "26c2f8823236ff517cf84412e173679cfae42e043b6fec81f9d984b562517e6f"
+ "ebe1f72295dbc3fdfc19d3240aa75515563f31dad83563f3a315acf9a0b351a2"
+ "3f0203010001",
"3081a2300d06092a864886f70d010101050003819030818d02818100ab9014dc"
+ "47d44b6d260fc1fef9ab022042fd9566e9d7b60c54100cb6e1d4edc98590467d"
+ "0502c17fce69d00ac5efb40b2cb167d8a44ab93d73c4d0f109fb5a26c2f88232"
+ "36ff517cf84412e173679cfae42e043b6fec81f9d984b562517e6febe1f72295"
+ "dbc3fdfc19d3240aa75515563f31dad83563f3a315acf9a0b351a23f22070201"
+ "0102020001",
// truncate sequence
"30819e300d06092a864886f70d010101050003818d0030818902818100ab9014"
+ "dc47d44b6d260fc1fef9ab022042fd9566e9d7b60c54100cb6e1d4edc9859046"
+ "7d0502c17fce69d00ac5efb40b2cb167d8a44ab93d73c4d0f109fb5a26c2f882"
+ "3236ff517cf84412e173679cfae42e043b6fec81f9d984b562517e6febe1f722"
+ "95dbc3fdfc19d3240aa75515563f31dad83563f3a315acf9a0b351a23f020301"
+ "00",
"30819e0d06092a864886f70d010101050003818d0030818902818100ab9014dc"
+ "47d44b6d260fc1fef9ab022042fd9566e9d7b60c54100cb6e1d4edc98590467d"
+ "0502c17fce69d00ac5efb40b2cb167d8a44ab93d73c4d0f109fb5a26c2f88232"
+ "36ff517cf84412e173679cfae42e043b6fec81f9d984b562517e6febe1f72295"
+ "dbc3fdfc19d3240aa75515563f31dad83563f3a315acf9a0b351a23f02030100"
+ "01",
"30819e300c06092a864886f70d0101010503818d0030818902818100ab9014dc"
+ "47d44b6d260fc1fef9ab022042fd9566e9d7b60c54100cb6e1d4edc98590467d"
+ "0502c17fce69d00ac5efb40b2cb167d8a44ab93d73c4d0f109fb5a26c2f88232"
+ "36ff517cf84412e173679cfae42e043b6fec81f9d984b562517e6febe1f72295"
+ "dbc3fdfc19d3240aa75515563f31dad83563f3a315acf9a0b351a23f02030100"
+ "01",
"30819e300c092a864886f70d010101050003818d0030818902818100ab9014dc"
+ "47d44b6d260fc1fef9ab022042fd9566e9d7b60c54100cb6e1d4edc98590467d"
+ "0502c17fce69d00ac5efb40b2cb167d8a44ab93d73c4d0f109fb5a26c2f88232"
+ "36ff517cf84412e173679cfae42e043b6fec81f9d984b562517e6febe1f72295"
+ "dbc3fdfc19d3240aa75515563f31dad83563f3a315acf9a0b351a23f02030100"
+ "01",
"30819d300d06092a864886f70d010101050003818b30818802818100ab9014dc"
+ "47d44b6d260fc1fef9ab022042fd9566e9d7b60c54100cb6e1d4edc98590467d"
+ "0502c17fce69d00ac5efb40b2cb167d8a44ab93d73c4d0f109fb5a26c2f88232"
+ "36ff517cf84412e173679cfae42e043b6fec81f9d984b562517e6febe1f72295"
+ "dbc3fdfc19d3240aa75515563f31dad83563f3a315acf9a0b351a23f02030100",
"30819d300d06092a864886f70d010101050003818b308188818100ab9014dc47"
+ "d44b6d260fc1fef9ab022042fd9566e9d7b60c54100cb6e1d4edc98590467d05"
+ "02c17fce69d00ac5efb40b2cb167d8a44ab93d73c4d0f109fb5a26c2f8823236"
+ "ff517cf84412e173679cfae42e043b6fec81f9d984b562517e6febe1f72295db"
+ "c3fdfc19d3240aa75515563f31dad83563f3a315acf9a0b351a23f0203010001",
// prepend empty sequence
"3081a13000300d06092a864886f70d010101050003818d0030818902818100ab"
+ "9014dc47d44b6d260fc1fef9ab022042fd9566e9d7b60c54100cb6e1d4edc985"
+ "90467d0502c17fce69d00ac5efb40b2cb167d8a44ab93d73c4d0f109fb5a26c2"
+ "f8823236ff517cf84412e173679cfae42e043b6fec81f9d984b562517e6febe1"
+ "f72295dbc3fdfc19d3240aa75515563f31dad83563f3a315acf9a0b351a23f02"
+ "03010001",
"3081a1300f300006092a864886f70d010101050003818d0030818902818100ab"
+ "9014dc47d44b6d260fc1fef9ab022042fd9566e9d7b60c54100cb6e1d4edc985"
+ "90467d0502c17fce69d00ac5efb40b2cb167d8a44ab93d73c4d0f109fb5a26c2"
+ "f8823236ff517cf84412e173679cfae42e043b6fec81f9d984b562517e6febe1"
+ "f72295dbc3fdfc19d3240aa75515563f31dad83563f3a315acf9a0b351a23f02"
+ "03010001",
"3081a0300d06092a864886f70d010101050003818e30818b300002818100ab90"
+ "14dc47d44b6d260fc1fef9ab022042fd9566e9d7b60c54100cb6e1d4edc98590"
+ "467d0502c17fce69d00ac5efb40b2cb167d8a44ab93d73c4d0f109fb5a26c2f8"
+ "823236ff517cf84412e173679cfae42e043b6fec81f9d984b562517e6febe1f7"
+ "2295dbc3fdfc19d3240aa75515563f31dad83563f3a315acf9a0b351a23f0203"
+ "010001",
// append empty sequence
"3081a1300d06092a864886f70d010101050003818d0030818902818100ab9014"
+ "dc47d44b6d260fc1fef9ab022042fd9566e9d7b60c54100cb6e1d4edc9859046"
+ "7d0502c17fce69d00ac5efb40b2cb167d8a44ab93d73c4d0f109fb5a26c2f882"
+ "3236ff517cf84412e173679cfae42e043b6fec81f9d984b562517e6febe1f722"
+ "95dbc3fdfc19d3240aa75515563f31dad83563f3a315acf9a0b351a23f020301"
+ "00013000",
"3081a1300f06092a864886f70d0101010500300003818d0030818902818100ab"
+ "9014dc47d44b6d260fc1fef9ab022042fd9566e9d7b60c54100cb6e1d4edc985"
+ "90467d0502c17fce69d00ac5efb40b2cb167d8a44ab93d73c4d0f109fb5a26c2"
+ "f8823236ff517cf84412e173679cfae42e043b6fec81f9d984b562517e6febe1"
+ "f72295dbc3fdfc19d3240aa75515563f31dad83563f3a315acf9a0b351a23f02"
+ "03010001",
"3081a0300d06092a864886f70d010101050003818e30818b02818100ab9014dc"
+ "47d44b6d260fc1fef9ab022042fd9566e9d7b60c54100cb6e1d4edc98590467d"
+ "0502c17fce69d00ac5efb40b2cb167d8a44ab93d73c4d0f109fb5a26c2f88232"
+ "36ff517cf84412e173679cfae42e043b6fec81f9d984b562517e6febe1f72295"
+ "dbc3fdfc19d3240aa75515563f31dad83563f3a315acf9a0b351a23f02030100"
+ "013000",
// sequence of sequence
"3081a230819f300d06092a864886f70d010101050003818d0030818902818100"
+ "ab9014dc47d44b6d260fc1fef9ab022042fd9566e9d7b60c54100cb6e1d4edc9"
+ "8590467d0502c17fce69d00ac5efb40b2cb167d8a44ab93d73c4d0f109fb5a26"
+ "c2f8823236ff517cf84412e173679cfae42e043b6fec81f9d984b562517e6feb"
+ "e1f72295dbc3fdfc19d3240aa75515563f31dad83563f3a315acf9a0b351a23f"
+ "0203010001",
"3081a1300f300d06092a864886f70d010101050003818d0030818902818100ab"
+ "9014dc47d44b6d260fc1fef9ab022042fd9566e9d7b60c54100cb6e1d4edc985"
+ "90467d0502c17fce69d00ac5efb40b2cb167d8a44ab93d73c4d0f109fb5a26c2"
+ "f8823236ff517cf84412e173679cfae42e043b6fec81f9d984b562517e6febe1"
+ "f72295dbc3fdfc19d3240aa75515563f31dad83563f3a315acf9a0b351a23f02"
+ "03010001",
"3081a1300d06092a864886f70d010101050003818f30818c30818902818100ab"
+ "9014dc47d44b6d260fc1fef9ab022042fd9566e9d7b60c54100cb6e1d4edc985"
+ "90467d0502c17fce69d00ac5efb40b2cb167d8a44ab93d73c4d0f109fb5a26c2"
+ "f8823236ff517cf84412e173679cfae42e043b6fec81f9d984b562517e6febe1"
+ "f72295dbc3fdfc19d3240aa75515563f31dad83563f3a315acf9a0b351a23f02"
+ "03010001",
// truncated sequence
"300f300d06092a864886f70d0101010500",
"30819d300b06092a864886f70d01010103818d0030818902818100ab9014dc47"
+ "d44b6d260fc1fef9ab022042fd9566e9d7b60c54100cb6e1d4edc98590467d05"
+ "02c17fce69d00ac5efb40b2cb167d8a44ab93d73c4d0f109fb5a26c2f8823236"
+ "ff517cf84412e173679cfae42e043b6fec81f9d984b562517e6febe1f72295db"
+ "c3fdfc19d3240aa75515563f31dad83563f3a315acf9a0b351a23f0203010001",
"308199300d06092a864886f70d010101050003818730818402818100ab9014dc"
+ "47d44b6d260fc1fef9ab022042fd9566e9d7b60c54100cb6e1d4edc98590467d"
+ "0502c17fce69d00ac5efb40b2cb167d8a44ab93d73c4d0f109fb5a26c2f88232"
+ "36ff517cf84412e173679cfae42e043b6fec81f9d984b562517e6febe1f72295"
+ "dbc3fdfc19d3240aa75515563f31dad83563f3a315acf9a0b351a23f",
// repeat element in sequence
"3082012f300d06092a864886f70d010101050003818d0030818902818100ab90"
+ "14dc47d44b6d260fc1fef9ab022042fd9566e9d7b60c54100cb6e1d4edc98590"
+ "467d0502c17fce69d00ac5efb40b2cb167d8a44ab93d73c4d0f109fb5a26c2f8"
+ "823236ff517cf84412e173679cfae42e043b6fec81f9d984b562517e6febe1f7"
+ "2295dbc3fdfc19d3240aa75515563f31dad83563f3a315acf9a0b351a23f0203"
+ "01000103818d0030818902818100ab9014dc47d44b6d260fc1fef9ab022042fd"
+ "9566e9d7b60c54100cb6e1d4edc98590467d0502c17fce69d00ac5efb40b2cb1"
+ "67d8a44ab93d73c4d0f109fb5a26c2f8823236ff517cf84412e173679cfae42e"
+ "043b6fec81f9d984b562517e6febe1f72295dbc3fdfc19d3240aa75515563f31"
+ "dad83563f3a315acf9a0b351a23f0203010001",
"3081a3300d06092a864886f70d010101050003819130818e02818100ab9014dc"
+ "47d44b6d260fc1fef9ab022042fd9566e9d7b60c54100cb6e1d4edc98590467d"
+ "0502c17fce69d00ac5efb40b2cb167d8a44ab93d73c4d0f109fb5a26c2f88232"
+ "36ff517cf84412e173679cfae42e043b6fec81f9d984b562517e6febe1f72295"
+ "dbc3fdfc19d3240aa75515563f31dad83563f3a315acf9a0b351a23f02030100"
+ "010203010001",
// long form encoding of length
"3081a030810d06092a864886f70d010101050003818d0030818902818100ab90"
+ "14dc47d44b6d260fc1fef9ab022042fd9566e9d7b60c54100cb6e1d4edc98590"
+ "467d0502c17fce69d00ac5efb40b2cb167d8a44ab93d73c4d0f109fb5a26c2f8"
+ "823236ff517cf84412e173679cfae42e043b6fec81f9d984b562517e6febe1f7"
+ "2295dbc3fdfc19d3240aa75515563f31dad83563f3a315acf9a0b351a23f0203"
+ "010001",
"3081a0300e0681092a864886f70d010101050003818d0030818902818100ab90"
+ "14dc47d44b6d260fc1fef9ab022042fd9566e9d7b60c54100cb6e1d4edc98590"
+ "467d0502c17fce69d00ac5efb40b2cb167d8a44ab93d73c4d0f109fb5a26c2f8"
+ "823236ff517cf84412e173679cfae42e043b6fec81f9d984b562517e6febe1f7"
+ "2295dbc3fdfc19d3240aa75515563f31dad83563f3a315acf9a0b351a23f0203"
+ "010001",
"3081a0300e06092a864886f70d01010105810003818d0030818902818100ab90"
+ "14dc47d44b6d260fc1fef9ab022042fd9566e9d7b60c54100cb6e1d4edc98590"
+ "467d0502c17fce69d00ac5efb40b2cb167d8a44ab93d73c4d0f109fb5a26c2f8"
+ "823236ff517cf84412e173679cfae42e043b6fec81f9d984b562517e6febe1f7"
+ "2295dbc3fdfc19d3240aa75515563f31dad83563f3a315acf9a0b351a23f0203"
+ "010001",
"30819f300d06092a864886f70d010101050003818d30818a02818100ab9014dc"
+ "47d44b6d260fc1fef9ab022042fd9566e9d7b60c54100cb6e1d4edc98590467d"
+ "0502c17fce69d00ac5efb40b2cb167d8a44ab93d73c4d0f109fb5a26c2f88232"
+ "36ff517cf84412e173679cfae42e043b6fec81f9d984b562517e6febe1f72295"
+ "dbc3fdfc19d3240aa75515563f31dad83563f3a315acf9a0b351a23f02810301"
+ "0001",
// removing oid
"3081943002050003818d0030818902818100ab9014dc47d44b6d260fc1fef9ab"
+ "022042fd9566e9d7b60c54100cb6e1d4edc98590467d0502c17fce69d00ac5ef"
+ "b40b2cb167d8a44ab93d73c4d0f109fb5a26c2f8823236ff517cf84412e17367"
+ "9cfae42e043b6fec81f9d984b562517e6febe1f72295dbc3fdfc19d3240aa755"
+ "15563f31dad83563f3a315acf9a0b351a23f0203010001",
// appending 0's to oid
"3081a1300f060b2a864886f70d0101010000050003818d0030818902818100ab"
+ "9014dc47d44b6d260fc1fef9ab022042fd9566e9d7b60c54100cb6e1d4edc985"
+ "90467d0502c17fce69d00ac5efb40b2cb167d8a44ab93d73c4d0f109fb5a26c2"
+ "f8823236ff517cf84412e173679cfae42e043b6fec81f9d984b562517e6febe1"
+ "f72295dbc3fdfc19d3240aa75515563f31dad83563f3a315acf9a0b351a23f02"
+ "03010001",
// prepending 0's to oid
"3081a1300f060b00002a864886f70d010101050003818d0030818902818100ab"
+ "9014dc47d44b6d260fc1fef9ab022042fd9566e9d7b60c54100cb6e1d4edc985"
+ "90467d0502c17fce69d00ac5efb40b2cb167d8a44ab93d73c4d0f109fb5a26c2"
+ "f8823236ff517cf84412e173679cfae42e043b6fec81f9d984b562517e6febe1"
+ "f72295dbc3fdfc19d3240aa75515563f31dad83563f3a315acf9a0b351a23f02"
+ "03010001",
// dropping value of oid
"30819630040600050003818d0030818902818100ab9014dc47d44b6d260fc1fe"
+ "f9ab022042fd9566e9d7b60c54100cb6e1d4edc98590467d0502c17fce69d00a"
+ "c5efb40b2cb167d8a44ab93d73c4d0f109fb5a26c2f8823236ff517cf84412e1"
+ "73679cfae42e043b6fec81f9d984b562517e6febe1f72295dbc3fdfc19d3240a"
+ "a75515563f31dad83563f3a315acf9a0b351a23f0203010001",
// modify first byte of oid
"30819f300d06092b864886f70d010101050003818d0030818902818100ab9014"
+ "dc47d44b6d260fc1fef9ab022042fd9566e9d7b60c54100cb6e1d4edc9859046"
+ "7d0502c17fce69d00ac5efb40b2cb167d8a44ab93d73c4d0f109fb5a26c2f882"
+ "3236ff517cf84412e173679cfae42e043b6fec81f9d984b562517e6febe1f722"
+ "95dbc3fdfc19d3240aa75515563f31dad83563f3a315acf9a0b351a23f020301"
+ "0001",
// modify last byte of oid
"30819f300d06092a864886f70d010100050003818d0030818902818100ab9014"
+ "dc47d44b6d260fc1fef9ab022042fd9566e9d7b60c54100cb6e1d4edc9859046"
+ "7d0502c17fce69d00ac5efb40b2cb167d8a44ab93d73c4d0f109fb5a26c2f882"
+ "3236ff517cf84412e173679cfae42e043b6fec81f9d984b562517e6febe1f722"
+ "95dbc3fdfc19d3240aa75515563f31dad83563f3a315acf9a0b351a23f020301"
+ "0001",
// truncate oid
"30819e300c06082a864886f70d0101050003818d0030818902818100ab9014dc"
+ "47d44b6d260fc1fef9ab022042fd9566e9d7b60c54100cb6e1d4edc98590467d"
+ "0502c17fce69d00ac5efb40b2cb167d8a44ab93d73c4d0f109fb5a26c2f88232"
+ "36ff517cf84412e173679cfae42e043b6fec81f9d984b562517e6febe1f72295"
+ "dbc3fdfc19d3240aa75515563f31dad83563f3a315acf9a0b351a23f02030100"
+ "01",
"30819e300c0608864886f70d010101050003818d0030818902818100ab9014dc"
+ "47d44b6d260fc1fef9ab022042fd9566e9d7b60c54100cb6e1d4edc98590467d"
+ "0502c17fce69d00ac5efb40b2cb167d8a44ab93d73c4d0f109fb5a26c2f88232"
+ "36ff517cf84412e173679cfae42e043b6fec81f9d984b562517e6febe1f72295"
+ "dbc3fdfc19d3240aa75515563f31dad83563f3a315acf9a0b351a23f02030100"
+ "01",
// wrong oid
"30819b300906052b0e03021a050003818d0030818902818100ab9014dc47d44b"
+ "6d260fc1fef9ab022042fd9566e9d7b60c54100cb6e1d4edc98590467d0502c1"
+ "7fce69d00ac5efb40b2cb167d8a44ab93d73c4d0f109fb5a26c2f8823236ff51"
+ "7cf84412e173679cfae42e043b6fec81f9d984b562517e6febe1f72295dbc3fd"
+ "fc19d3240aa75515563f31dad83563f3a315acf9a0b351a23f0203010001",
"30819f300d0609608648016503040201050003818d0030818902818100ab9014"
+ "dc47d44b6d260fc1fef9ab022042fd9566e9d7b60c54100cb6e1d4edc9859046"
+ "7d0502c17fce69d00ac5efb40b2cb167d8a44ab93d73c4d0f109fb5a26c2f882"
+ "3236ff517cf84412e173679cfae42e043b6fec81f9d984b562517e6febe1f722"
+ "95dbc3fdfc19d3240aa75515563f31dad83563f3a315acf9a0b351a23f020301"
+ "0001",
// longer oid
"3081a0300e060a2a864886f70d01010101050003818d0030818902818100ab90"
+ "14dc47d44b6d260fc1fef9ab022042fd9566e9d7b60c54100cb6e1d4edc98590"
+ "467d0502c17fce69d00ac5efb40b2cb167d8a44ab93d73c4d0f109fb5a26c2f8"
+ "823236ff517cf84412e173679cfae42e043b6fec81f9d984b562517e6febe1f7"
+ "2295dbc3fdfc19d3240aa75515563f31dad83563f3a315acf9a0b351a23f0203"
+ "010001",
// oid with modified node
"30819f300d06092a864886f70d010111050003818d0030818902818100ab9014"
+ "dc47d44b6d260fc1fef9ab022042fd9566e9d7b60c54100cb6e1d4edc9859046"
+ "7d0502c17fce69d00ac5efb40b2cb167d8a44ab93d73c4d0f109fb5a26c2f882"
+ "3236ff517cf84412e173679cfae42e043b6fec81f9d984b562517e6febe1f722"
+ "95dbc3fdfc19d3240aa75515563f31dad83563f3a315acf9a0b351a23f020301"
+ "0001",
"3081a33011060d2a864886f70d01018880808001050003818d00308189028181"
+ "00ab9014dc47d44b6d260fc1fef9ab022042fd9566e9d7b60c54100cb6e1d4ed"
+ "c98590467d0502c17fce69d00ac5efb40b2cb167d8a44ab93d73c4d0f109fb5a"
+ "26c2f8823236ff517cf84412e173679cfae42e043b6fec81f9d984b562517e6f"
+ "ebe1f72295dbc3fdfc19d3240aa75515563f31dad83563f3a315acf9a0b351a2"
+ "3f0203010001",
// large integer in oid
"3081a8301606122a864886f70d010182808080808080808001050003818d0030"
+ "818902818100ab9014dc47d44b6d260fc1fef9ab022042fd9566e9d7b60c5410"
+ "0cb6e1d4edc98590467d0502c17fce69d00ac5efb40b2cb167d8a44ab93d73c4"
+ "d0f109fb5a26c2f8823236ff517cf84412e173679cfae42e043b6fec81f9d984"
+ "b562517e6febe1f72295dbc3fdfc19d3240aa75515563f31dad83563f3a315ac"
+ "f9a0b351a23f0203010001",
// oid with invalid node
"3081a0300e060a2a864886f70d010101e0050003818d0030818902818100ab90"
+ "14dc47d44b6d260fc1fef9ab022042fd9566e9d7b60c54100cb6e1d4edc98590"
+ "467d0502c17fce69d00ac5efb40b2cb167d8a44ab93d73c4d0f109fb5a26c2f8"
+ "823236ff517cf84412e173679cfae42e043b6fec81f9d984b562517e6febe1f7"
+ "2295dbc3fdfc19d3240aa75515563f31dad83563f3a315acf9a0b351a23f0203"
+ "010001",
"3081a0300e060a2a80864886f70d010101050003818d0030818902818100ab90"
+ "14dc47d44b6d260fc1fef9ab022042fd9566e9d7b60c54100cb6e1d4edc98590"
+ "467d0502c17fce69d00ac5efb40b2cb167d8a44ab93d73c4d0f109fb5a26c2f8"
+ "823236ff517cf84412e173679cfae42e043b6fec81f9d984b562517e6febe1f7"
+ "2295dbc3fdfc19d3240aa75515563f31dad83563f3a315acf9a0b351a23f0203"
+ "010001",
// appending 0's to null
"3081a1300f06092a864886f70d0101010502000003818d0030818902818100ab"
+ "9014dc47d44b6d260fc1fef9ab022042fd9566e9d7b60c54100cb6e1d4edc985"
+ "90467d0502c17fce69d00ac5efb40b2cb167d8a44ab93d73c4d0f109fb5a26c2"
+ "f8823236ff517cf84412e173679cfae42e043b6fec81f9d984b562517e6febe1"
+ "f72295dbc3fdfc19d3240aa75515563f31dad83563f3a315acf9a0b351a23f02"
+ "03010001",
// appending 0's to bit string
"3081a1300d06092a864886f70d010101050003818f0030818902818100ab9014"
+ "dc47d44b6d260fc1fef9ab022042fd9566e9d7b60c54100cb6e1d4edc9859046"
+ "7d0502c17fce69d00ac5efb40b2cb167d8a44ab93d73c4d0f109fb5a26c2f882"
+ "3236ff517cf84412e173679cfae42e043b6fec81f9d984b562517e6febe1f722"
+ "95dbc3fdfc19d3240aa75515563f31dad83563f3a315acf9a0b351a23f020301"
+ "00010000",
// prepending 0's to bit string
"3081a1300d06092a864886f70d010101050003818f00000030818902818100ab"
+ "9014dc47d44b6d260fc1fef9ab022042fd9566e9d7b60c54100cb6e1d4edc985"
+ "90467d0502c17fce69d00ac5efb40b2cb167d8a44ab93d73c4d0f109fb5a26c2"
+ "f8823236ff517cf84412e173679cfae42e043b6fec81f9d984b562517e6febe1"
+ "f72295dbc3fdfc19d3240aa75515563f31dad83563f3a315acf9a0b351a23f02"
+ "03010001",
// modify first byte of bit string
"30819f300d06092a864886f70d010101050003818d0130818902818100ab9014"
+ "dc47d44b6d260fc1fef9ab022042fd9566e9d7b60c54100cb6e1d4edc9859046"
+ "7d0502c17fce69d00ac5efb40b2cb167d8a44ab93d73c4d0f109fb5a26c2f882"
+ "3236ff517cf84412e173679cfae42e043b6fec81f9d984b562517e6febe1f722"
+ "95dbc3fdfc19d3240aa75515563f31dad83563f3a315acf9a0b351a23f020301"
+ "0001",
// modify last byte of bit string
"30819f300d06092a864886f70d010101050003818d0030818902818100ab9014"
+ "dc47d44b6d260fc1fef9ab022042fd9566e9d7b60c54100cb6e1d4edc9859046"
+ "7d0502c17fce69d00ac5efb40b2cb167d8a44ab93d73c4d0f109fb5a26c2f882"
+ "3236ff517cf84412e173679cfae42e043b6fec81f9d984b562517e6febe1f722"
+ "95dbc3fdfc19d3240aa75515563f31dad83563f3a315acf9a0b351a23f020301"
+ "0000",
// truncate bit string
"30819e300d06092a864886f70d010101050003818c0030818902818100ab9014"
+ "dc47d44b6d260fc1fef9ab022042fd9566e9d7b60c54100cb6e1d4edc9859046"
+ "7d0502c17fce69d00ac5efb40b2cb167d8a44ab93d73c4d0f109fb5a26c2f882"
+ "3236ff517cf84412e173679cfae42e043b6fec81f9d984b562517e6febe1f722"
+ "95dbc3fdfc19d3240aa75515563f31dad83563f3a315acf9a0b351a23f020301"
+ "00",
"30819e300d06092a864886f70d010101050003818c30818902818100ab9014dc"
+ "47d44b6d260fc1fef9ab022042fd9566e9d7b60c54100cb6e1d4edc98590467d"
+ "0502c17fce69d00ac5efb40b2cb167d8a44ab93d73c4d0f109fb5a26c2f88232"
+ "36ff517cf84412e173679cfae42e043b6fec81f9d984b562517e6febe1f72295"
+ "dbc3fdfc19d3240aa75515563f31dad83563f3a315acf9a0b351a23f02030100"
+ "01",
// removing integer
"3018300d06092a864886f70d0101010500030730050203010001",
// appending 0's to integer
"3081a0300d06092a864886f70d010101050003818e30818b02818300ab9014dc"
+ "47d44b6d260fc1fef9ab022042fd9566e9d7b60c54100cb6e1d4edc98590467d"
+ "0502c17fce69d00ac5efb40b2cb167d8a44ab93d73c4d0f109fb5a26c2f88232"
+ "36ff517cf84412e173679cfae42e043b6fec81f9d984b562517e6febe1f72295"
+ "dbc3fdfc19d3240aa75515563f31dad83563f3a315acf9a0b351a23f00000203"
+ "010001",
"3081a0300d06092a864886f70d010101050003818e30818b02818100ab9014dc"
+ "47d44b6d260fc1fef9ab022042fd9566e9d7b60c54100cb6e1d4edc98590467d"
+ "0502c17fce69d00ac5efb40b2cb167d8a44ab93d73c4d0f109fb5a26c2f88232"
+ "36ff517cf84412e173679cfae42e043b6fec81f9d984b562517e6febe1f72295"
+ "dbc3fdfc19d3240aa75515563f31dad83563f3a315acf9a0b351a23f02050100"
+ "010000",
// prepending 0's to integer
"3081a0300d06092a864886f70d010101050003818e30818b028183000000ab90"
+ "14dc47d44b6d260fc1fef9ab022042fd9566e9d7b60c54100cb6e1d4edc98590"
+ "467d0502c17fce69d00ac5efb40b2cb167d8a44ab93d73c4d0f109fb5a26c2f8"
+ "823236ff517cf84412e173679cfae42e043b6fec81f9d984b562517e6febe1f7"
+ "2295dbc3fdfc19d3240aa75515563f31dad83563f3a315acf9a0b351a23f0203"
+ "010001",
"3081a0300d06092a864886f70d010101050003818e30818b02818100ab9014dc"
+ "47d44b6d260fc1fef9ab022042fd9566e9d7b60c54100cb6e1d4edc98590467d"
+ "0502c17fce69d00ac5efb40b2cb167d8a44ab93d73c4d0f109fb5a26c2f88232"
+ "36ff517cf84412e173679cfae42e043b6fec81f9d984b562517e6febe1f72295"
+ "dbc3fdfc19d3240aa75515563f31dad83563f3a315acf9a0b351a23f02050000"
+ "010001",
// dropping value of integer
"301a300d06092a864886f70d01010105000309300702000203010001",
"30819b300d06092a864886f70d010101050003818930818602818100ab9014dc"
+ "47d44b6d260fc1fef9ab022042fd9566e9d7b60c54100cb6e1d4edc98590467d"
+ "0502c17fce69d00ac5efb40b2cb167d8a44ab93d73c4d0f109fb5a26c2f88232"
+ "36ff517cf84412e173679cfae42e043b6fec81f9d984b562517e6febe1f72295"
+ "dbc3fdfc19d3240aa75515563f31dad83563f3a315acf9a0b351a23f0200",
// modify first byte of integer
"30819e300d06092a864886f70d010101050003818c30818902818101ab9014dc"
+ "47d44b6d260fc1fef9ab022042fd9566e9d7b60c54100cb6e1d4edc98590467d"
+ "0502c17fce69d00ac5efb40b2cb167d8a44ab93d73c4d0f109fb5a26c2f88232"
+ "36ff517cf84412e173679cfae42e043b6fec81f9d984b562517e6febe1f72295"
+ "dbc3fdfc19d3240aa75515563f31dad83563f3a315acf9a0b351a23f02030100"
+ "01",
"30819e300d06092a864886f70d010101050003818c30818902818100ab9014dc"
+ "47d44b6d260fc1fef9ab022042fd9566e9d7b60c54100cb6e1d4edc98590467d"
+ "0502c17fce69d00ac5efb40b2cb167d8a44ab93d73c4d0f109fb5a26c2f88232"
+ "36ff517cf84412e173679cfae42e043b6fec81f9d984b562517e6febe1f72295"
+ "dbc3fdfc19d3240aa75515563f31dad83563f3a315acf9a0b351a23f02030000"
+ "01",
// modify last byte of integer
"30819e300d06092a864886f70d010101050003818c30818902818100ab9014dc"
+ "47d44b6d260fc1fef9ab022042fd9566e9d7b60c54100cb6e1d4edc98590467d"
+ "0502c17fce69d00ac5efb40b2cb167d8a44ab93d73c4d0f109fb5a26c2f88232"
+ "36ff517cf84412e173679cfae42e043b6fec81f9d984b562517e6febe1f72295"
+ "dbc3fdfc19d3240aa75515563f31dad83563f3a315acf9a0b351a23e02030100"
+ "01",
"30819e300d06092a864886f70d010101050003818c30818902818100ab9014dc"
+ "47d44b6d260fc1fef9ab022042fd9566e9d7b60c54100cb6e1d4edc98590467d"
+ "0502c17fce69d00ac5efb40b2cb167d8a44ab93d73c4d0f109fb5a26c2f88232"
+ "36ff517cf84412e173679cfae42e043b6fec81f9d984b562517e6febe1f72295"
+ "dbc3fdfc19d3240aa75515563f31dad83563f3a315acf9a0b351a23f02030100"
+ "00",
// truncate integer
"30819d300d06092a864886f70d010101050003818b30818802818000ab9014dc"
+ "47d44b6d260fc1fef9ab022042fd9566e9d7b60c54100cb6e1d4edc98590467d"
+ "0502c17fce69d00ac5efb40b2cb167d8a44ab93d73c4d0f109fb5a26c2f88232"
+ "36ff517cf84412e173679cfae42e043b6fec81f9d984b562517e6febe1f72295"
+ "dbc3fdfc19d3240aa75515563f31dad83563f3a315acf9a0b351a20203010001",
"30819d300d06092a864886f70d010101050003818b308188028180ab9014dc47"
+ "d44b6d260fc1fef9ab022042fd9566e9d7b60c54100cb6e1d4edc98590467d05"
+ "02c17fce69d00ac5efb40b2cb167d8a44ab93d73c4d0f109fb5a26c2f8823236"
+ "ff517cf84412e173679cfae42e043b6fec81f9d984b562517e6febe1f72295db"
+ "c3fdfc19d3240aa75515563f31dad83563f3a315acf9a0b351a23f0203010001",
"30819d300d06092a864886f70d010101050003818b30818802818100ab9014dc"
+ "47d44b6d260fc1fef9ab022042fd9566e9d7b60c54100cb6e1d4edc98590467d"
+ "0502c17fce69d00ac5efb40b2cb167d8a44ab93d73c4d0f109fb5a26c2f88232"
+ "36ff517cf84412e173679cfae42e043b6fec81f9d984b562517e6febe1f72295"
+ "dbc3fdfc19d3240aa75515563f31dad83563f3a315acf9a0b351a23f02020100",
"30819d300d06092a864886f70d010101050003818b30818802818100ab9014dc"
+ "47d44b6d260fc1fef9ab022042fd9566e9d7b60c54100cb6e1d4edc98590467d"
+ "0502c17fce69d00ac5efb40b2cb167d8a44ab93d73c4d0f109fb5a26c2f88232"
+ "36ff517cf84412e173679cfae42e043b6fec81f9d984b562517e6febe1f72295"
+ "dbc3fdfc19d3240aa75515563f31dad83563f3a315acf9a0b351a23f02020001",
// leading ff in integer
"30819f300d06092a864886f70d010101050003818d30818a028182ff00ab9014"
+ "dc47d44b6d260fc1fef9ab022042fd9566e9d7b60c54100cb6e1d4edc9859046"
+ "7d0502c17fce69d00ac5efb40b2cb167d8a44ab93d73c4d0f109fb5a26c2f882"
+ "3236ff517cf84412e173679cfae42e043b6fec81f9d984b562517e6febe1f722"
+ "95dbc3fdfc19d3240aa75515563f31dad83563f3a315acf9a0b351a23f020301"
+ "0001",
"30819f300d06092a864886f70d010101050003818d30818a02818100ab9014dc"
+ "47d44b6d260fc1fef9ab022042fd9566e9d7b60c54100cb6e1d4edc98590467d"
+ "0502c17fce69d00ac5efb40b2cb167d8a44ab93d73c4d0f109fb5a26c2f88232"
+ "36ff517cf84412e173679cfae42e043b6fec81f9d984b562517e6febe1f72295"
+ "dbc3fdfc19d3240aa75515563f31dad83563f3a315acf9a0b351a23f0204ff01"
+ "0001",
// infinity
"301b300d06092a864886f70d0101010500030a30080901800203010001",
"30819c300d06092a864886f70d010101050003818a30818702818100ab9014dc"
+ "47d44b6d260fc1fef9ab022042fd9566e9d7b60c54100cb6e1d4edc98590467d"
+ "0502c17fce69d00ac5efb40b2cb167d8a44ab93d73c4d0f109fb5a26c2f88232"
+ "36ff517cf84412e173679cfae42e043b6fec81f9d984b562517e6febe1f72295"
+ "dbc3fdfc19d3240aa75515563f31dad83563f3a315acf9a0b351a23f090180",
// n=0
"301c300d06092a864886f70d0101010500030b0030080201000203010001",
// negative n
"30819f300d06092a864886f70d010101050003818d00308189028181ff546feb"
+ "23b82bb492d9f03e010654fddfbd026a99162849f3abeff3491e2b12367a6fb9"
+ "82fafd3e8031962ff53a104bf4d34e98275bb546c28c3b2f0ef604a5d93d077d"
+ "cdc900ae8307bbed1e8c9863051bd1fbc490137e06267b4a9dae8190141e08dd"
+ "6a243c0203e62cdbf558aaeaa9c0ce2527ca9c0c5cea53065f4cae5dc1020301"
+ "0001",
// e=0
"30819d300d06092a864886f70d010101050003818b0030818702818100ab9014"
+ "dc47d44b6d260fc1fef9ab022042fd9566e9d7b60c54100cb6e1d4edc9859046"
+ "7d0502c17fce69d00ac5efb40b2cb167d8a44ab93d73c4d0f109fb5a26c2f882"
+ "3236ff517cf84412e173679cfae42e043b6fec81f9d984b562517e6febe1f722"
+ "95dbc3fdfc19d3240aa75515563f31dad83563f3a315acf9a0b351a23f020100",
// e=1
"30819d300d06092a864886f70d010101050003818b0030818702818100ab9014"
+ "dc47d44b6d260fc1fef9ab022042fd9566e9d7b60c54100cb6e1d4edc9859046"
+ "7d0502c17fce69d00ac5efb40b2cb167d8a44ab93d73c4d0f109fb5a26c2f882"
+ "3236ff517cf84412e173679cfae42e043b6fec81f9d984b562517e6febe1f722"
+ "95dbc3fdfc19d3240aa75515563f31dad83563f3a315acf9a0b351a23f020101",
// e=2
"30819d300d06092a864886f70d010101050003818b0030818702818100ab9014"
+ "dc47d44b6d260fc1fef9ab022042fd9566e9d7b60c54100cb6e1d4edc9859046"
+ "7d0502c17fce69d00ac5efb40b2cb167d8a44ab93d73c4d0f109fb5a26c2f882"
+ "3236ff517cf84412e173679cfae42e043b6fec81f9d984b562517e6febe1f722"
+ "95dbc3fdfc19d3240aa75515563f31dad83563f3a315acf9a0b351a23f020102",
// negative e
"30819f300d06092a864886f70d010101050003818d0030818902818100ab9014"
+ "dc47d44b6d260fc1fef9ab022042fd9566e9d7b60c54100cb6e1d4edc9859046"
+ "7d0502c17fce69d00ac5efb40b2cb167d8a44ab93d73c4d0f109fb5a26c2f882"
+ "3236ff517cf84412e173679cfae42e043b6fec81f9d984b562517e6febe1f722"
+ "95dbc3fdfc19d3240aa75515563f31dad83563f3a315acf9a0b351a23f0203fe"
+ "ffff",
};
private void checkPrivateCrtKey(RSAPrivateCrtKey key, int expectedKeySize) throws Exception {
BigInteger p = key.getPrimeP();
BigInteger q = key.getPrimeQ();
BigInteger n = key.getModulus();
BigInteger e = key.getPublicExponent();
BigInteger d = key.getPrivateExponent();
BigInteger dp = key.getPrimeExponentP();
BigInteger dq = key.getPrimeExponentQ();
BigInteger crtCoeff = key.getCrtCoefficient();
// Simple test that (n,d,e) is a valid RSA key.
assertEquals(n, p.multiply(q));
assertEquals(expectedKeySize, n.bitLength());
int certainty = 80;
assertTrue(p.isProbablePrime(certainty));
assertTrue(q.isProbablePrime(certainty));
// Very simple checks for weak random number generators.
RandomUtil.checkPrime(p);
RandomUtil.checkPrime(q);
assertTrue(d.bitLength() > expectedKeySize / 2);
// TODO(bleichen): Keys that are very imbalanced can be broken with elliptic curve factoring.
// Add other checks. E.g. for the size of dp and dq
assertTrue(p.bitLength() > 256);
assertTrue(q.bitLength() > 256);
BigInteger p1 = p.subtract(BigInteger.ONE);
BigInteger q1 = q.subtract(BigInteger.ONE);
BigInteger phi = p1.multiply(q1);
BigInteger order = phi.divide(p1.gcd(q1)); // maximal order of elements
assertEquals(BigInteger.ONE, d.multiply(e).mod(order));
assertEquals(d.mod(p1), dp.mod(p1));
assertEquals(d.mod(q1), dq.mod(q1));
assertEquals(q.multiply(crtCoeff).mod(p), BigInteger.ONE);
}
private void checkPublicKey(RSAPublicKey pub, RSAPrivateKey priv) {
assertEquals(pub.getModulus(), priv.getModulus());
BigInteger e = pub.getPublicExponent();
// Checks that e > 1. [CVE-1999-1444]
assertEquals(e.compareTo(BigInteger.ONE), 1);
}
private void checkKeyPair(KeyPair keypair, int keySizeInBits) throws Exception {
RSAPublicKey pub = (RSAPublicKey) keypair.getPublic();
RSAPrivateKey priv = (RSAPrivateKey) keypair.getPrivate();
if (priv instanceof RSAPrivateCrtKey) {
checkPrivateCrtKey((RSAPrivateCrtKey) priv, keySizeInBits);
} else {
// Using a CRT key leads to 6-7 times better performance than not using the CRT.
// Such a perfomance loss makes a library almost useless. Thus we consider this
// a bug.
fail("Expecting an RSAPrivateCrtKey instead of " + priv.getClass().getName());
}
checkPublicKey(pub, priv);
}
public void testKeyGenerationSize(int keySizeInBits) throws Exception {
KeyPairGenerator keyGen = KeyPairGenerator.getInstance("RSA");
keyGen.initialize(keySizeInBits);
KeyPair keypair = keyGen.genKeyPair();
checkKeyPair(keypair, keySizeInBits);
}
@ExcludedTest(
providers = {ProviderType.BOUNCY_CASTLE},
comment = "KeyPairGenerator.RSA is removed")
public void testKeyGeneration() throws Exception {
testKeyGenerationSize(1024);
testKeyGenerationSize(2048);
}
/**
* Checks whether decoding and again encoding an RSA public key results
* in the same encoding.
* This is a regression test. Failing this test implies that the encoding has changed.
* Such a failure does not need to be a bug, since several encoding for the same key are
* possible.
*/
@ExcludedTest(
providers = {ProviderType.BOUNCY_CASTLE},
comment = "KeyFactory.RSA is removed")
public void testEncodeDecodePublic() throws Exception {
KeyFactory kf = KeyFactory.getInstance("RSA");
byte[] encoded = TestUtil.hexToBytes(ENCODED_PUBLIC_KEY);
X509EncodedKeySpec spec = new X509EncodedKeySpec(encoded);
RSAPublicKey pub = (RSAPublicKey) kf.generatePublic(spec);
assertEquals("The test assumes that the public key is in X.509 format",
"X.509", pub.getFormat());
assertEquals(ENCODED_PUBLIC_KEY, TestUtil.bytesToHex(pub.getEncoded()));
}
/**
* Parses a list of modified encodings of an RSA public key.
* Expects that any modification either results in an InvalidKeySpecException
* or an altered PublicKey.
* This test has mostly "defense in depth" characteristic, since applications should
* never accept unauthenticated public keys.
*/
@ExcludedTest(
providers = {ProviderType.BOUNCY_CASTLE},
comment = "KeyFactory.RSA is removed")
public void testModifiedPublicKeyDecoding() throws Exception {
KeyFactory kf = KeyFactory.getInstance("RSA");
int cnt = 0;
for (String encoded : MODIFIED_PUBLIC_KEY) {
X509EncodedKeySpec spec = new X509EncodedKeySpec(TestUtil.hexToBytes(encoded));
try {
RSAPublicKey unusedKey = (RSAPublicKey) kf.generatePublic(spec);
// TODO(bleichen): check the keys that are accepted.
// To decide whether a key should have been rejected or not the test vectors must be
// divided into several categories:
// - keys that use BER encoding: these are OK
// - keys that include additional fields or garbage: might be OK
// - keys where the modification does not change the values: are probably OK
// - keys with missing parameters: should be rejected
// - keys with impossible values (negative n, negative e): should be rejected.
} catch (InvalidKeySpecException ex) {
// expected
} catch (Exception ex) {
System.out.println("generatePublic throws:" + ex.getMessage() + " for " + encoded);
cnt++;
}
}
assertEquals(0, cnt);
}
// TODO(bleichen): This test is only needed as long as there are open issues.
}