我正在使用由 makecert 生成的证书,该证书具有私钥和公钥。
java端使用这个公钥加密数据,.net解密回来。
我正在尝试解密 Java 的加密 64 位编码字符串并获取错误数据。
为了查看.Net 端是否一切正常,我首先尝试使用公钥加密,然后使用相同的证书使用私钥进行解密。我的代码看起来像这样。
X509Certificate2 cert = GetCert(key, StoreName.My, StoreLocation.LocalMachine);
RSACryptoServiceProvider provider = (RSACryptoServiceProvider)cert.PrivateKey;
RSACryptoServiceProvider publicprovider = (RSACryptoServiceProvider)cert.PublicKey.Key;
if (cert.HasPrivateKey)
MessageBox.Show("Got private key");
byte[] encrypted = publicprovider.Encrypt(Encoding.UTF8.GetBytes(text), false);
byte[] decryptedBytes = provider.Decrypt(encrypted, false);
即使在这里我也收到错误。我错过了什么吗?
证书看起来对公钥和私钥都有效。
最佳答案
我在使用自签名证书时遇到了同样的问题,问题是我使用开关生成证书 -sky signature
而不是 -sky exchange
(您使用签名进行签名和交换进行加密/解密)
这是我对 makecert 有效的完整命令:
makecert -r -pe -a sha1 -n "CN=MyName" -ss my -sr CurrentUser -sky exchange
关于.net - 使用 x509 证书的 rsacryptoserviceprovider c#,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/1623189/