【发布时间】:2017-04-05 12:34:29
【问题描述】:
我有两个本地控制台应用程序,一个是生成公钥和私钥的服务器,另一个是客户端,它通过消费服务从服务器接收公钥并将加密消息发送到服务器。 服务然后尝试解密消息并将其保存在服务器中,但是在调用 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 是必需的?)但这只是让它现在更加混乱。
如果您能给我一些解决此问题的建议,我将不胜感激。
【问题讨论】:
标签: c# wcf client-server rsa rsacryptoserviceprovider