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对象.
对于可能涉及的任何人,我通过使用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)
我能够重新创建公钥.
| 归档时间: |
|
| 查看次数: |
3190 次 |
| 最近记录: |