从Bouncy Castle的byte []获取ECPoint/ECPublicKeyParameters

ini*_*mfs 3 java bouncycastle elliptic-curve public-key-encryption diffie-hellman

到目前为止,我已经设法在充气城堡的轻量级API中生成ECDHE对.但是,我尝试从byte []重新创建公钥时遇到问题.

由于ECPublicKeyParameters对象只有一个方法getQ(),我假设重建密钥所需的全部内容.其他参数如使用的曲线(P-521)保持不变.

我正在做以下事情:

AsymmetricCipherKeyPair kp = kpgen.generateKeyPair(); //ECDHE Key Generator

ECPublicKeyParameters pubKey = (ECPublicKeyParameters)kp.getPublic();
byte[] aPubKeybytes = pubKey.getQ().getEncoded(false); //Should I set to true or false?
Run Code Online (Sandbox Code Playgroud)

除非有另一种方法来获取公钥pubKey的原始字节,否则我没有看到在不调用返回ECPoint对象的方法getQ()的情况下获取字节的方法.

我的问题是如何使用bouncy castle的轻量级API将byte []重建为ECPoint对象.或者,更好的是,如何使用从原始pubKey对象派生的字节数组重建整个ECPublicKeyParameter对象.

ini*_*mfs 8

对于可能涉及的任何人,我通过使用PublicKeyFactory和SubjectPublicKeyInfoFactory来对密钥进行编码和解码,从而解决了这个问题.

使用:

byte[] key = SubjectPublicKeyInfoFactory.createSubjectPublicKeyInfo(pubKey).getEncoded();
Run Code Online (Sandbox Code Playgroud)

我能够获得密钥的原始字节.

和使用:

ECPublicKeyParameters bpubKey = (ECPublicKeyParameters)PublicKeyFactory.createKey(key);
Run Code Online (Sandbox Code Playgroud)

我能够重新创建公钥.