我正在使用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
感谢 拉吉
答案 0 :(得分:1)
看起来你没有使用相同的算法。一个使用SHA256,另一个使用SHA256withRSA。
根据此示例尝试MessageDigest: