gpt4 book ai didi

java - 如何在 BouncyCaSTLe Java 中对 ECDH 公钥进行 DER 编码

转载 作者:塔克拉玛干 更新时间:2023-11-02 19:35:51 24 4
gpt4 key购买 nike

所以我知道如何将 BouncyCaSTLe C# 库中的公钥编码/解码为字节数组:

编码:

PublicKey = SubjectPublicKeyInfoFactory.CreateSubjectPublicKeyInfo(p1.Public).GetDerEncoded();

解码:

ECPublicKeyParameters pubKey = (ECPublicKeyParameters)PublicKeyFactory.CreateKey(OtherPublicKey);

我似乎无法弄清楚如何在 BouncyCaSTLe 库的 Java 版本中执行此操作,因为在该库的 Java 版本中似乎没有 SubjectPublicKeyInfoFactory 对象。但是,Java 中似乎有一个 PublicKeyFactory 类,所以看起来我可以使用相同的代码,但我不知道如何在 Java 库中对公钥进行 DER 编码。谁能帮忙??谢谢!

-----编辑---------------------------------------- ------------------

好的,这是我目前在 C# 中的内容:

创建ECDH实例:

public static ECDHBasicAgreement CreateECDHInstance(out byte[] PublicKey)
{
IAsymmetricCipherKeyPairGenerator g = GeneratorUtilities.GetKeyPairGenerator("ECDH");

FpCurve curve = new FpCurve(
new BigInteger("883423532389192164791648750360308885314476597252960362792450860609699839"), // q
new BigInteger("7fffffffffffffffffffffff7fffffffffff8000000000007ffffffffffc", 16), // a
new BigInteger("6b016c3bdcf18941d0d654921475ca71a9db2fb27d1d37796185c2942c0a", 16)); // b

ECDomainParameters ecSpec = new ECDomainParameters(
curve,
curve.DecodePoint(Hex.Decode("020ffa963cdca8816ccc33b8642bedf905c3d358573d3f27fbbd3b3cb9aaaf")), // G
new BigInteger("883423532389192164791648750360308884807550341691627752275345424702807307"), // n
BigInteger.One); // h

g.Init(new ECKeyGenerationParameters(ecSpec, new SecureRandom()));

AsymmetricCipherKeyPair aKeyPair = g.GenerateKeyPair();
ECDHBasicAgreement aKeyAgreeBasic = new ECDHBasicAgreement();
aKeyAgreeBasic.Init(aKeyPair.Private);

PublicKey = SubjectPublicKeyInfoFactory.CreateSubjectPublicKeyInfo(aKeyPair.Public).GetDerEncoded();

return aKeyAgreeBasic;
}

这完美地创建并返回了一个 ECDHBasicAgreement 对象,并以 der 编码的字节数组形式输出了一个公钥。这是我在 java 中的内容:

public void testECDH() throws Exception
{
AsymmetricCipherKeyPairGenerator g = new ECKeyPairGenerator();

Fp curve = new Fp(
new BigInteger("883423532389192164791648750360308885314476597252960362792450860609699839"), // q
new BigInteger("7fffffffffffffffffffffff7fffffffffff8000000000007ffffffffffc", 16), // a
new BigInteger("6b016c3bdcf18941d0d654921475ca71a9db2fb27d1d37796185c2942c0a", 16)); // b

ECDomainParameters ecSpec = new ECDomainParameters(
curve,
curve.decodePoint(Hex.decode("020ffa963cdca8816ccc33b8642bedf905c3d358573d3f27fbbd3b3cb9aaaf")), // G
new BigInteger("883423532389192164791648750360308884807550341691627752275345424702807307"), // n
BigInteger.ONE); // h

g.init(new ECKeyGenerationParameters(ecSpec, new SecureRandom()));

AsymmetricCipherKeyPair aKeyPair = g.generateKeyPair();
ECDHBasicAgreement aKeyAgreeBasic = new ECDHBasicAgreement();
aKeyAgreeBasic.init(aKeyPair.getPrivate());

// The part that doesn't work
//byte[] publickey = SubjectPublicKeyInfoFactory.CreateSubjectPublicKeyInfo(aKeyPair.getPublic()).GetDerEncoded();
}

在 java 中,似乎没有 SubjectPublicKeyInfoFactory 类或可以采用 aKeyPair.getPublic() 并能够生成 DER 编码字节数组的等效类。任何人都可以帮忙!??!?我快无计可施了!谢谢!!!!!!

------------编辑 2 ---------------------------------- --------------------------------------

好的,这就是我现在的位置:

public void test2() throws Exception
{
ECKeyPairGenerator g = new ECKeyPairGenerator();

Fp curve = new Fp(
new BigInteger("883423532389192164791648750360308885314476597252960362792450860609699839"), // q
new BigInteger("7fffffffffffffffffffffff7fffffffffff8000000000007ffffffffffc", 16), // a
new BigInteger("6b016c3bdcf18941d0d654921475ca71a9db2fb27d1d37796185c2942c0a", 16)); // b

ECDomainParameters ecP = new ECDomainParameters(
curve,
curve.decodePoint(Hex.decode("020ffa963cdca8816ccc33b8642bedf905c3d358573d3f27fbbd3b3cb9aaaf")), // G
new BigInteger("883423532389192164791648750360308884807550341691627752275345424702807307"), // n
BigInteger.ONE); // h

g.init(new ECKeyGenerationParameters(ecP, new SecureRandom()));

// Generate key pair
AsymmetricCipherKeyPair aKeys = g.generateKeyPair();

JCEECPublicKey jpub = new JCEECPublicKey("EC", (ECPublicKeyParameters)aKeys.getPublic());
JCEECPrivateKey jpriv = new JCEECPrivateKey("EC", (ECPrivateKeyParameters)aKeys.getPrivate());

KeyPair aKeyPair = new KeyPair(jpub, jpriv);

ECDHBasicAgreement aKeyAgree = new ECDHBasicAgreement();

aKeyAgree.init(aKeys.getPrivate());

byte[] encoded = aKeyPair.getPublic().getEncoded();
// The part that breaks now (Exception DERNull)
ECPublicKeyParameters decoded = decodeECPublicKeyParameters(encoded);
}

public static ECPublicKeyParameters decodeECPublicKeyParameters(byte[] pkByte) throws IOException {
return (ECPublicKeyParameters) PublicKeyFactory.createKey(pkByte);
}

所以我已经能够将公钥/私钥获取到 JCEEC Key 对象中,并且能够对它们进行编码。当我尝试解码它们时,我得到一个 DERNull 异常。我运行了一些其他测试并使用常规 native java KeyPairGenerator 生成了 key ,并且能够对 key 进行编码/解码,因此我知道此方法确实有效。当我将 AsymmetricCipherKeys 转换为 JCEEC key 时,我认为缺少了一些东西。我确实注意到 JCEECPublicKey 构造中还有另一个参数,即 ECKeySpec 的第三个参数。唯一的麻烦是,我不确定如何从我目前拥有的代码中获取 ECKeySpec(或者如果这就是开始的问题)。还有其他建议吗?谢谢!!!

最佳答案

您是否尝试过使用 BouncycaSTLe SubjectPublicKeyInfo 类?像这样的东西:

byte [] derEncoded;
//...
SubjectPublicKeyInfo pkInfo = new SubjectPublicKeyInfo((ASN1Sequence)ASN1Object.fromByteArray(derEncoded))

编辑:

有一种简单但有些不尽如人意的方法。您可以使用 JCEPublicKey 类,它有一个生成(我认为)正确答案的 getEncoded() 方法。

编辑 2:

边学边学 :) 事实证明,您必须在算法参数中识别椭圆曲线,这是有道理的。这是执行此操作的一个小改动。

    g.init(new ECKeyGenerationParameters(ecP, new SecureRandom()));

// Generate key pair
AsymmetricCipherKeyPair aKeys = g.generateKeyPair();

ECParameterSpec ecSpec = new ECParameterSpec(ecP.getCurve(), ecP.getG(), ecP.getN());
JCEECPublicKey jpub = new JCEECPublicKey("EC",
(ECPublicKeyParameters) aKeys.getPublic(), ecSpec);
JCEECPrivateKey jpriv = new JCEECPrivateKey("EC",
(ECPrivateKeyParameters) aKeys.getPrivate(), jpub, ecSpec);

关于java - 如何在 BouncyCaSTLe Java 中对 ECDH 公钥进行 DER 编码,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/8014281/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com