我有两个本地控制台应用程序,一个是生成公钥和私钥的服务器,另一个是通过使用服务从服务器接收公钥并将加密消息发送到服务器的客户端。 然后,该服务尝试解密该消息并将其保存在服务器中,但是当调用RSA.Decrypt时,会抛出CryptographicException,指出该参数不正确。
代码示例:
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?)但它现在让它更加混乱。
如果你能给我一些解决方法,我将不胜感激。
答案 0 :(得分:0)
问题是我在Visual Studio中以调试模式运行应用程序。
我尝试使用实际的Release可执行文件,一切都按预期运行。