📄 dhtest.java
字号:
ECParameterSpec ecSpec = new ECParameterSpec( curve, curve.decodePoint(Hex.decode("020ffa963cdca8816ccc33b8642bedf905c3d358573d3f27fbbd3b3cb9aaaf")), // G new BigInteger("883423532389192164791648750360308884807550341691627752275345424702807307")); // n g.initialize(ecSpec, new SecureRandom()); // // a side // KeyPair aKeyPair = g.generateKeyPair(); KeyAgreement aKeyAgree = KeyAgreement.getInstance("ECDH", "BC"); aKeyAgree.init(aKeyPair.getPrivate()); // // b side // KeyPair bKeyPair = g.generateKeyPair(); KeyAgreement bKeyAgree = KeyAgreement.getInstance("ECDH", "BC"); bKeyAgree.init(bKeyPair.getPrivate()); // // agreement // aKeyAgree.doPhase(bKeyPair.getPublic(), true); bKeyAgree.doPhase(aKeyPair.getPublic(), true); BigInteger k1 = new BigInteger(aKeyAgree.generateSecret()); BigInteger k2 = new BigInteger(bKeyAgree.generateSecret()); if (!k1.equals(k2)) { return new SimpleTestResult(false, "ECDH 2-way test failed"); } // // public key encoding test // byte[] pubEnc = aKeyPair.getPublic().getEncoded(); KeyFactory keyFac = KeyFactory.getInstance("ECDH", "BC"); X509EncodedKeySpec pubX509 = new X509EncodedKeySpec(pubEnc); ECPublicKey pubKey = (ECPublicKey)keyFac.generatePublic(pubX509); if (!pubKey.getQ().equals(((ECPublicKey)aKeyPair.getPublic()).getQ())) { return new SimpleTestResult(false, "ECDH public key encoding (Q test) failed"); } if (!pubKey.getParameters().getG().equals(((ECPublicKey)aKeyPair.getPublic()).getParameters().getG())) { return new SimpleTestResult(false, "ECDH public key encoding (G test) failed"); } // // private key encoding test // byte[] privEnc = aKeyPair.getPrivate().getEncoded(); PKCS8EncodedKeySpec privPKCS8 = new PKCS8EncodedKeySpec(privEnc); ECPrivateKey privKey = (ECPrivateKey)keyFac.generatePrivate(privPKCS8); if (!privKey.getD().equals(((ECPrivateKey)aKeyPair.getPrivate()).getD())) { return new SimpleTestResult(false, "ECDH private key encoding (D test) failed"); } if (!privKey.getParameters().getG().equals(((ECPrivateKey)aKeyPair.getPrivate()).getParameters().getG())) { return new SimpleTestResult(false, "ECDH private key encoding (G test) failed"); } } catch (Exception e) { return new SimpleTestResult(false, "ECDH 2-way test failed - exception: " + e); } return new SimpleTestResult(true, this.getName() + ": Okay"); } private TestResult testECDHC() { try { KeyPairGenerator g = KeyPairGenerator.getInstance("ECDH", "BC"); ECCurve curve = new ECCurve.Fp( new BigInteger("883423532389192164791648750360308885314476597252960362792450860609699839"), // q new BigInteger("7fffffffffffffffffffffff7fffffffffff8000000000007ffffffffffc", 16), // a new BigInteger("6b016c3bdcf18941d0d654921475ca71a9db2fb27d1d37796185c2942c0a", 16)); // b ECParameterSpec ecSpec = new ECParameterSpec( curve, curve.decodePoint(Hex.decode("020ffa963cdca8816ccc33b8642bedf905c3d358573d3f27fbbd3b3cb9aaaf")), // G new BigInteger("883423532389192164791648750360308884807550341691627752275345424702807307")); // n g.initialize(ecSpec, new SecureRandom()); // // a side // KeyPair aKeyPair = g.generateKeyPair(); KeyAgreement aKeyAgree = KeyAgreement.getInstance("ECDHC", "BC"); aKeyAgree.init(aKeyPair.getPrivate()); // // b side // KeyPair bKeyPair = g.generateKeyPair(); KeyAgreement bKeyAgree = KeyAgreement.getInstance("ECDHC", "BC"); bKeyAgree.init(bKeyPair.getPrivate()); // // agreement // aKeyAgree.doPhase(bKeyPair.getPublic(), true); bKeyAgree.doPhase(aKeyPair.getPublic(), true); BigInteger k1 = new BigInteger(aKeyAgree.generateSecret()); BigInteger k2 = new BigInteger(bKeyAgree.generateSecret()); if (!k1.equals(k2)) { return new SimpleTestResult(false, "ECDHC 2-way test failed"); } // // public key encoding test // byte[] pubEnc = aKeyPair.getPublic().getEncoded(); KeyFactory keyFac = KeyFactory.getInstance("ECDH", "BC"); X509EncodedKeySpec pubX509 = new X509EncodedKeySpec(pubEnc); ECPublicKey pubKey = (ECPublicKey)keyFac.generatePublic(pubX509); if (!pubKey.getQ().equals(((ECPublicKey)aKeyPair.getPublic()).getQ())) { return new SimpleTestResult(false, "ECDH public key encoding (Q test) failed"); } if (!pubKey.getParameters().getN().equals(((ECPublicKey)aKeyPair.getPublic()).getParameters().getN())) { return new SimpleTestResult(false, "ECDH public key encoding (N test) failed"); } // // private key encoding test // byte[] privEnc = aKeyPair.getPrivate().getEncoded(); PKCS8EncodedKeySpec privPKCS8 = new PKCS8EncodedKeySpec(privEnc); ECPrivateKey privKey = (ECPrivateKey)keyFac.generatePrivate(privPKCS8); if (!privKey.getD().equals(((ECPrivateKey)aKeyPair.getPrivate()).getD())) { return new SimpleTestResult(false, "ECDH private key encoding (D test) failed"); } if (!privKey.getParameters().getN().equals(((ECPrivateKey)aKeyPair.getPrivate()).getParameters().getN())) { return new SimpleTestResult(false, "ECDH private key encoding (N test) failed"); } } catch (Exception e) { return new SimpleTestResult(false, "ECDHC 2-way test failed - exception: " + e); } return new SimpleTestResult(true, this.getName() + ": Okay"); } private TestResult testExceptions() { DHParameterSpec dhParams = new DHParameterSpec(p512, g512); try { KeyAgreement aKeyAgree = KeyAgreement.getInstance("DH", "BC"); aKeyAgree.generateSecret("DES"); } catch (IllegalStateException e) { // okay } catch (Exception e) { return new SimpleTestResult(false, "Unexpected exception: " + e, e); } return new SimpleTestResult(true, this.getName() + ": Okay"); } private boolean arrayEquals( byte[] a, byte[] b) { if (a.length != b.length) { return false; } for (int i = 0; i != a.length; i++) { if (a[i] != b[i]) { return false; } } return true; } public TestResult perform() { TestResult result; result = testGP(512, g512, p512); if (!result.isSuccessful()) { return result; } result = testGP(768, g768, p768); if (!result.isSuccessful()) { return result; } result = testGP(1024, g1024, p1024); if (!result.isSuccessful()) { return result; } result = testRandom(256); if (!result.isSuccessful()) { return result; } result = testECDH(); if (!result.isSuccessful()) { return result; } result = testECDHC(); if (!result.isSuccessful()) { return result; } result = testExceptions(); if (!result.isSuccessful()) { return result; } return result; } public static void main( String[] args) { Security.addProvider(new BouncyCastleProvider()); DHTest test = new DHTest(); TestResult result = test.perform(); System.out.println(result); }}
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -