无法验证在C#中创建的签名

时间:2013-12-14 10:52:04

标签: c# java security rsa x509certificate

我正在使用C#创建签名并验证java中的签名。这总是返回false。要求帮助我找出我做错的地方。

用于创建签名的C#代码:

SHA256CryptoServiceProvider sha = new SHA256CryptoServiceProvider();
byte[] hash = sha.ComputeHash(Encoding.UTF8.GetBytes(data));
RSACryptoServiceProvider key = (RSACryptoServiceProvider)privateCert.PrivateKey;
RSACryptoServiceProvider signer = new RSACryptoServiceProvider();
signer.FromXmlString(key.ToXmlString(true));
byte[] signedHash = signer.SignData(hash, CryptoConfig.MapNameToOID("SHA256"));          

用于验证签名的java代码:

Signature signature = Signature.getInstance("SHA256withRSA");
signature.initVerify(certificate);
signature.update(data);
boolean retValue= signature.verify(signedHash);
return retValue; // always returns false

感谢 拉吉

1 个答案:

答案 0 :(得分:1)

看起来你没有使用相同的算法。一个使用SHA256,另一个使用SHA256withRSA。

根据此示例尝试MessageDigest:

http://www.mkyong.com/java/java-sha-hashing-example/