6
我有下面的测试,它隔离了使用System.Security.Cryptograph.RSACryptoServiceProvider时遇到的问题。问题是r.Decrypt抛出异常“密钥不存在”。如果我使用privateKeyXml进行加密和解密(而不是在解密时使用publicKeyXml),那么它按预期工作。当然我不想分享私钥,我需要能够用公钥解密。 有没有人看到我在这里做错了?“键不存在”抛出异常。我究竟做错了什么?
[Fact]
public void BasicEncryptDecrypt()
{
var cspParameters = new CspParameters() { Flags = CspProviderFlags.CreateEphemeralKey | CspProviderFlags.NoPrompt };
string privateKeyXml = null;
string publicKeyXml = null;
using(var r = new RSACryptoServiceProvider(2048, cspParameters)){
r.PersistKeyInCsp = false;
privateKeyXml = r.ToXmlString(true);
publicKeyXml = r.ToXmlString(false);
}
byte[] encrypted = null;
string decrypted = null;
using (var r = new RSACryptoServiceProvider(2048, cspParameters))
{
r.FromXmlString(privateKeyXml);
encrypted = r.Encrypt(Encoding.UTF8.GetBytes("foobar"), false);
}
using (var r = new RSACryptoServiceProvider(2048, cspParameters))
{
r.FromXmlString(publicKeyXml);
decrypted = Encoding.UTF8.GetString(r.Decrypt(encrypted, false));
}
Assert.Equal("foobar", decrypted);
}
可能重复[如何使用的RSACryptoServiceProvider解密加密的文本?](http://stackoverflow.com/questions/6763741/how -crypt-text-using-rsacryptoserviceprovider) –
不要忘记非对称加密是如何工作的:你总是用公钥进行加密并用私钥解密。 –
是的,这是一个骗局。谢谢 –