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

本文关键字:创建 验证 | 更新日期: 2024-09-22 02:14:40

我使用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

谢谢Raj

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

看起来您并没有使用相同的算法。一种是使用SHA256,另一种是带有RSA的SHA256。

尝试MessageDigest,如下例所示:

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