我有两个本地控制台应用程序,一个是生成公钥和私钥的服务器,另一个是通过使用服务从服务器接收公钥并向服务器发送加密消息的客户端。然后,该服务尝试解密消息并将其保存在服务器中,但抛出一个 CryptographicException,指出 RSA 时该参数不正确。调用解密。
代码示例:
byte[] decryptedByteMessage;
using (RSACryptoServiceProvider RSA = new RSACryptoServiceProvider())
{
decryptedByteMessage = RSADecrypt(encryptedByteMessage, privKey);
}
解密
static public byte[] RSADecrypt(byte[] DataToDecrypt, RSAParameters RSAKeyInfo)
{
try
{
byte[] decryptedData;
using (RSACryptoServiceProvider RSA = new RSACryptoServiceProvider())
{
RSA.ImportParameters(RSAKeyInfo);
decryptedData = RSA.Decrypt(DataToDecrypt, false); // exception here
}
return decryptedData;
}
catch (CryptographicException e)
{
Console.Write(e.Message);
return null;
}
}
我可以看到键是正确的,并且相同的代码在单个控制台应用程序中工作正常。我试图寻找一个解决方案,(也许需要CspParameters?(,但它只是让它目前更加混乱。
如果您能给我一些解决此问题的指示,我将不胜感激。
问题是我在Visual Studio中以调试模式运行应用程序。
我尝试使用实际的发布可执行文件,一切都按预期运行。