OpenSSL始终无法验证Java中从Bouncy Castle生成的签名

时间:2019-05-07 07:40:39

标签: java openssl rsa bouncycastle sha

我正在尝试从文件生成签名,以便由客户端使用OpenSSL对其进行验证,以便使用Bouncy Castle在Java中实现相应的openSSL命令:

openssl.exe dgst -sha256 -sign privateKey.pem -out \data.txt.sig \data.txt

使用充气城堡1.57和Java,我们从文件中获取字节数组签名,我可以在代码中对其进行验证。私有,公共和证书是从openSSL生成的。

所以要生成证书:

从pem私钥文件中读取私钥:

PEMParser pemParser = new PEMParser(new FileReader(PRIVATE_FILE_PATH));
                    PKCS8EncryptedPrivateKeyInfo encryptedPrivateKeyInfo = (PKCS8EncryptedPrivateKeyInfo) pemParser.readObject();
JceOpenSSLPKCS8DecryptorProviderBuilder jce = new JceOpenSSLPKCS8DecryptorProviderBuilder();
jce.setProvider("BC");
InputDecryptorProvider decProv = jce.build(password.toCharArray());
PrivateKeyInfo info = encryptedPrivateKeyInfo.decryptPrivateKeyInfo(decProv);
JcaPEMKeyConverter pemKeyConverter = new JcaPEMKeyConverter();
PrivateKey pk = pemKeyConverter.getPrivateKey(info);

并生成RSA SHA 256签名并将结果写入签名文件:

byte[] data = Files.readAllBytes(Paths.get(txtFileToSignPath));
Signature sig = Signature.getInstance("SHA256withRSA");
sig.initSign(pk);
sig.update(data);
byte[] signature = sig.sign();
FileOutputStream dfis = new FileOutputStream(SignaturefilePath);
dfis.write(bytesToWrite);
dfis.close();

通过编程,我可以验证从上面的代码以及从开放SSL生成的签名:

Signature verifySignature = Signature.getInstance("SHA256withRSA"); 
byte[] signatureBytes =  
Files.readAllBytes(Paths.get(SignaturefilePath);
verifySignature.initVerify(getPublicKeyFromCertFile(CERT_PEM));
verifySignature.update(data);
verifySignature.verify(signatureBytes);

另一方面,openSSL通过验证从代码生成的签名而总是“验证失败”。

OpenSSL是否能够直接验证字节签名数组,或者我缺少任何内容?

0 个答案:

没有答案