📄 pkixpolicymappingtest.java
字号:
new BigInteger("7deb1b194a85bcfd29cf871411468adbc987650903e3bacc8338c449ca7b32efd39ffc33bc84412fcd7df18d23ce9d7c25ea910b1ae9985373e0273b4dca7f2e0db3b7314056ac67fd277f8f89cf2fd73c34c6ca69f9ba477143d2b0e2445548aa0b4a8473095182631da46844c356f5e5c7522eb54b5a33f11d730ead9c0cff", 16), new BigInteger("ef4cede573cea47f83699b814de4302edb60eefe426c52e17bd7870ec7c6b7a24fe55282ebb73775f369157726fcfb988def2b40350bdca9e5b418340288f649", 16), new BigInteger("97c7737d1b9a0088c3c7b528539247fd2a1593e7e01cef18848755be82f4a45aa093276cb0cbf118cb41117540a78f3fc471ba5d69f0042274defc9161265721", 16), new BigInteger("6c641094e24d172728b8da3c2777e69adfd0839085be7e38c7c4a2dd00b1ae969f2ec9d23e7e37090fcd449a40af0ed463fe1c612d6810d6b4f58b7bfa31eb5f", 16), new BigInteger("70b7123e8e69dfa76feb1236d0a686144b00e9232ed52b73847e74ef3af71fb45ccb24261f40d27f98101e230cf27b977a5d5f1f15f6cf48d5cb1da2a3a3b87f", 16), new BigInteger("e38f5750d97e270996a286df2e653fd26c242106436f5bab0f4c7a9e654ce02665d5a281f2c412456f2d1fa26586ef04a9adac9004ca7f913162cb28e13bf40d", 16)); // // ca keys // RSAPublicKeySpec caPubKeySpec = new RSAPublicKeySpec( new BigInteger("b259d2d6e627a768c94be36164c2d9fc79d97aab9253140e5bf17751197731d6f7540d2509e7b9ffee0a70a6e26d56e92d2edd7f85aba85600b69089f35f6bdbf3c298e05842535d9f064e6b0391cb7d306e0a2d20c4dfb4e7b49a9640bdea26c10ad69c3f05007ce2513cee44cfe01998e62b6c3637d3fc0391079b26ee36d5", 16), new BigInteger("11", 16)); RSAPrivateCrtKeySpec caPrivKeySpec = new RSAPrivateCrtKeySpec( new BigInteger("b259d2d6e627a768c94be36164c2d9fc79d97aab9253140e5bf17751197731d6f7540d2509e7b9ffee0a70a6e26d56e92d2edd7f85aba85600b69089f35f6bdbf3c298e05842535d9f064e6b0391cb7d306e0a2d20c4dfb4e7b49a9640bdea26c10ad69c3f05007ce2513cee44cfe01998e62b6c3637d3fc0391079b26ee36d5", 16), new BigInteger("11", 16), new BigInteger("92e08f83cc9920746989ca5034dcb384a094fb9c5a6288fcc4304424ab8f56388f72652d8fafc65a4b9020896f2cde297080f2a540e7b7ce5af0b3446e1258d1dd7f245cf54124b4c6e17da21b90a0ebd22605e6f45c9f136d7a13eaac1c0f7487de8bd6d924972408ebb58af71e76fd7b012a8d0e165f3ae2e5077a8648e619", 16), new BigInteger("f75e80839b9b9379f1cf1128f321639757dba514642c206bbbd99f9a4846208b3e93fbbe5e0527cc59b1d4b929d9555853004c7c8b30ee6a213c3d1bb7415d03", 16), new BigInteger("b892d9ebdbfc37e397256dd8a5d3123534d1f03726284743ddc6be3a709edb696fc40c7d902ed804c6eee730eee3d5b20bf6bd8d87a296813c87d3b3cc9d7947", 16), new BigInteger("1d1a2d3ca8e52068b3094d501c9a842fec37f54db16e9a67070a8b3f53cc03d4257ad252a1a640eadd603724d7bf3737914b544ae332eedf4f34436cac25ceb5", 16), new BigInteger("6c929e4e81672fef49d9c825163fec97c4b7ba7acb26c0824638ac22605d7201c94625770984f78a56e6e25904fe7db407099cad9b14588841b94f5ab498dded", 16), new BigInteger("dae7651ee69ad1d081ec5e7188ae126f6004ff39556bde90e0b870962fa7b926d070686d8244fe5a9aa709a95686a104614834b0ada4b10f53197a5cb4c97339", 16)); // // set up the keys // KeyFactory fact = KeyFactory.getInstance("RSA", "BC"); PrivateKey caPrivKey = fact.generatePrivate(caPrivKeySpec); PublicKey caPubKey = fact.generatePublic(caPubKeySpec); PrivateKey intPrivKey = fact.generatePrivate(intPrivKeySpec); PublicKey intPubKey = fact.generatePublic(intPubKeySpec); PrivateKey privKey = fact.generatePrivate(privKeySpec); PublicKey pubKey = fact.generatePublic(pubKeySpec); X509Certificate trustCert = createTrustCert(caPubKey, caPrivKey); ASN1EncodableVector intPolicies = null; Hashtable map = null; ASN1EncodableVector policies = null; Set requirePolicies = null; X509Certificate intCert = null; X509Certificate endCert = null; /** * valid test_00 */ intPolicies = new ASN1EncodableVector(); intPolicies.add(new PolicyInformation(new DERObjectIdentifier("2.5.29.32.0"))); map = new Hashtable(); map.put("2.16.840.1.101.3.2.1.48.1","2.16.840.1.101.3.2.1.48.2"); intCert = createIntmedCert(intPubKey, caPrivKey, caPubKey, intPolicies, map); policies = new ASN1EncodableVector(); policies.add(new PolicyInformation(new DERObjectIdentifier("2.16.840.1.101.3.2.1.48.2"))); endCert = createEndEntityCert(pubKey, intPrivKey, intPubKey, policies); requirePolicies = null; String msg = testPolicies(0, trustCert, intCert, endCert, requirePolicies, true); checkMessage(0, msg, ""); /** * test_01 */ intPolicies = new ASN1EncodableVector(); intPolicies.add(new PolicyInformation(new DERObjectIdentifier("2.5.29.32.0"))); map = new Hashtable(); map.put("2.16.840.1.101.3.2.1.48.1","2.16.840.1.101.3.2.1.48.2"); intCert = createIntmedCert(intPubKey, caPrivKey, caPubKey, intPolicies, map); policies = new ASN1EncodableVector(); policies.add(new PolicyInformation(new DERObjectIdentifier("2.16.840.1.101.3.2.1.48.2"))); endCert = createEndEntityCert(pubKey, intPrivKey, intPubKey, policies); requirePolicies = new HashSet(); requirePolicies.add("2.16.840.1.101.3.2.1.48.1"); msg = testPolicies(1, trustCert, intCert, endCert, requirePolicies, true); checkMessage(1, msg, ""); /** * test_02 */ intPolicies = new ASN1EncodableVector(); intPolicies.add(new PolicyInformation(new DERObjectIdentifier("2.5.29.32.0"))); map = new Hashtable(); map.put("2.16.840.1.101.3.2.1.48.1","2.16.840.1.101.3.2.1.48.2"); intCert = createIntmedCert(intPubKey, caPrivKey, caPubKey, intPolicies, map); policies = new ASN1EncodableVector(); policies.add(new PolicyInformation(new DERObjectIdentifier("2.16.840.1.101.3.2.1.48.2"))); endCert = createEndEntityCert(pubKey, intPrivKey, intPubKey, policies); requirePolicies = new HashSet(); requirePolicies.add("2.5.29.32.0"); msg = testPolicies(2, trustCert, intCert, endCert, requirePolicies, true); checkMessage(2, msg, ""); /** * test_03 */ intPolicies = new ASN1EncodableVector(); intPolicies.add(new PolicyInformation(new DERObjectIdentifier("2.16.840.1.101.3.2.1.48.3"))); intPolicies.add(new PolicyInformation(new DERObjectIdentifier("2.5.29.32.0"))); map = new Hashtable(); map.put("2.16.840.1.101.3.2.1.48.1","2.16.840.1.101.3.2.1.48.2"); intCert = createIntmedCert(intPubKey, caPrivKey, caPubKey, intPolicies, map); policies = new ASN1EncodableVector(); policies.add(new PolicyInformation(new DERObjectIdentifier("2.16.840.1.101.3.2.1.48.2"))); endCert = createEndEntityCert(pubKey, intPrivKey, intPubKey, policies); requirePolicies = new HashSet(); requirePolicies.add("2.16.840.1.101.3.2.1.48.1"); msg = testPolicies(3, trustCert, intCert, endCert, requirePolicies, true); checkMessage(3, msg, ""); /** * test_04 */ intPolicies = new ASN1EncodableVector(); intPolicies.add(new PolicyInformation(new DERObjectIdentifier("2.16.840.1.101.3.2.1.48.3"))); intPolicies.add(new PolicyInformation(new DERObjectIdentifier("2.5.29.32.0"))); map = new Hashtable(); map.put("2.16.840.1.101.3.2.1.48.1","2.16.840.1.101.3.2.1.48.2"); intCert = createIntmedCert(intPubKey, caPrivKey, caPubKey, intPolicies, map); policies = new ASN1EncodableVector(); policies.add(new PolicyInformation(new DERObjectIdentifier("2.16.840.1.101.3.2.1.48.3"))); endCert = createEndEntityCert(pubKey, intPrivKey, intPubKey, policies); requirePolicies = new HashSet(); requirePolicies.add("2.16.840.1.101.3.2.1.48.3"); msg = testPolicies(4, trustCert, intCert, endCert, requirePolicies, true); checkMessage(4, msg, ""); /** * test_05 */ intPolicies = new ASN1EncodableVector(); intPolicies.add(new PolicyInformation(new DERObjectIdentifier("2.5.29.32.0"))); map = new Hashtable(); map.put("2.16.840.1.101.3.2.1.48.1","2.16.840.1.101.3.2.1.48.2"); intCert = createIntmedCert(intPubKey, caPrivKey, caPubKey, intPolicies, map); policies = new ASN1EncodableVector(); policies.add(new PolicyInformation(new DERObjectIdentifier("2.16.840.1.101.3.2.1.48.2"))); endCert = createEndEntityCert(pubKey, intPrivKey, intPubKey, policies); requirePolicies = new HashSet(); requirePolicies.add("2.16.840.1.101.3.2.1.48.2"); msg = testPolicies(5, trustCert, intCert, endCert, requirePolicies, false); checkMessage(5, msg, "Path processing failed on policy."); /** * test_06 */ intPolicies = new ASN1EncodableVector(); intPolicies.add(new PolicyInformation(new DERObjectIdentifier("2.5.29.32.0"))); map = new Hashtable(); map.put("2.16.840.1.101.3.2.1.48.1","2.16.840.1.101.3.2.1.48.2"); intCert = createIntmedCert(intPubKey, caPrivKey, caPubKey, intPolicies, map); policies = new ASN1EncodableVector(); policies.add(new PolicyInformation(new DERObjectIdentifier("2.16.840.1.101.3.2.1.48.1"))); endCert = createEndEntityCert(pubKey, intPrivKey, intPubKey, policies); requirePolicies = new HashSet(); requirePolicies.add("2.16.840.1.101.3.2.1.48.1"); msg = testPolicies(6, trustCert, intCert, endCert, requirePolicies, true); checkMessage(6, msg, ""); /** * test_07 */ intPolicies = new ASN1EncodableVector(); intPolicies.add(new PolicyInformation(new DERObjectIdentifier("2.5.29.32.0"))); map = new Hashtable(); map.put("2.16.840.1.101.3.2.1.48.1","2.16.840.1.101.3.2.1.48.2"); intCert = createIntmedCert(intPubKey, caPrivKey, caPubKey, intPolicies, map); policies = new ASN1EncodableVector(); policies.add(new PolicyInformation(new DERObjectIdentifier("2.16.840.1.101.3.2.1.48.2"))); endCert = createEndEntityCert(pubKey, intPrivKey, intPubKey, policies); requirePolicies = new HashSet(); requirePolicies.add("2.16.840.1.101.3.2.1.48.3"); msg = testPolicies(7, trustCert, intCert, endCert, requirePolicies, false); checkMessage(7, msg, "Path processing failed on policy."); /** * test_08 */ intPolicies = new ASN1EncodableVector(); intPolicies.add(new PolicyInformation(new DERObjectIdentifier("2.5.29.32.0"))); map = new Hashtable(); map.put("2.16.840.1.101.3.2.1.48.1","2.16.840.1.101.3.2.1.48.2"); intCert = createIntmedCert(intPubKey, caPrivKey, caPubKey, intPolicies, map); policies = new ASN1EncodableVector(); policies.add(new PolicyInformation(new DERObjectIdentifier("2.16.840.1.101.3.2.1.48.3"))); endCert = createEndEntityCert(pubKey, intPrivKey, intPubKey, policies); requirePolicies = new HashSet(); requirePolicies.add("2.16.840.1.101.3.2.1.48.1"); msg = testPolicies(8, trustCert, intCert, endCert, requirePolicies, false); checkMessage(8, msg, "Path processing failed on policy."); } private void checkMessage( int index, String msg, String expected) { if (!msg.equals(expected)) { fail("test " + index + " failed got: " + msg + " expected: " + expected); } } public static void main( String[] args) { Security.addProvider(new BouncyCastleProvider()); runTest(new PKIXPolicyMappingTest()); }}
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -