我需要将Java转换为C#,因此需要从java.security API迁移到BouncyCastle轻量级API。
我的工作代码(java.security)如下所示:
private byte[] computeSignature(byte[] message, PrivateKey key) {
Signature signature = Signature.getInstance("NONEwithRSA");
signature.initSign(privateKey);
signature.update(message);
return signature.sign();
}这是我的核实:
private void verifySignature(byte[] signature, byte[] message, PublicKey publicKey) {
Signature signature = Signature.getInstance("NONEwithRSA");
signature.initVerify(publicKey);
signature.update(message);
System.out.println(signer.verify(result) ? "OK" : "FAIL");
}现在,我试图将它迁移到BC,如下所示:
NONEwithRSA算法的问题(不确定如何添加)
私有DefaultSignatureAlgorithmIdentifierFinder().find("NONEwithRSA");computeSignature(byte[] message,AsymmetricKeyParameter key) { AlgorithmIdentifier sigAlgId = new DefaultDigestAlgorithmIdentifierFinder().find(sigAlgId);AlgorithmIdentifier digAlgId = new DefaultDigestAlgorithmIdentifierFinder().find(sigAlgId);ContentSigner signer = new BcRSAContentSignerBuilder(sigAlgId,digAlgId).build(key);signer.getOutputStream().write(Arrays.copyOf(message,message.length,0,digAlgId);signer=()};你有什么意见建议?或者可以将NONEwithRSA算法迁移到BC中吗?我假设我需要写我自己的签名者,但是作为BC的新手和BC文档,我无法独自处理这个问题。
发布于 2014-02-21 01:00:26
试试这个:
RSABlindedEngine engine = new RSABlindedEngine();
PKCS1Encoding paddedEngine = new PKCS1Encoding(engine);
paddedEngine.init(true, privateKey);
return paddedEngine.processBlock(message, 0, message.length);https://stackoverflow.com/questions/21876156
复制相似问题