⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 dhtest.java

📁 bouncycastle 是一个JAVA安全提供者
💻 JAVA
📖 第 1 页 / 共 2 页
字号:
            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 + -