关于Decrypt解密的问题,困惑,困惑。我都要郁闷死了

guoshaohong 2005-04-12 09:59:38
有这样一个方法实现解密的功能:

public string DecryptData(byte[] encrypted)
{
//RSACryptoServiceProvider
rsaCSP = new RSACryptoServiceProvider();
byte[] fromEncrypt;
rsaCSP.ImportParameters(rsaPrivateParams);
fromEncrypt = rsaCSP.Decrypt(encrypted, false);
ASCIIEncoding myAscii = new ASCIIEncoding();
return myAscii.GetString(fromEncrypt);
}

其中rsaCSP,rsaPrivateParams是类中实例对象时在构造函数中创建好的。
我的问题是这样:
我加密后的返回值byte[]直接进行放到解密方法中正常解密;
可是我将加密后的返回值byte[]放到System.Text.ASCIIEncoding.ASCII.GetString()方法中生成一个string型的数值,然后我再用System.Text.ASCIIEncoding.ASCII.GetBytes()方法将这个string型的数值生成一个byte[]型的数值,将这个数值放到解密方法中就出错了,出错信息如下:
不正确的长度。
我验证过了经过两次转换后的数值打印出来后和直接从加密方法中返回来的数值一样。我强调一点是输出到屏幕时字符一样。
我现在不知道错误在哪里?还有我不知道如何将加密后的byte[]数值转成string然后再转回去传到加密方法中。请告知
...全文
459 1 打赏 收藏 转发到动态 举报
写回复
用AI写文章
1 条回复
切换为时间正序
请发表友善的回复…
发表回复
guoshaohong 2005-04-12
  • 打赏
  • 举报
回复
报的错误是“不正确的数据”

62,046

社区成员

发帖
与我相关
我的任务
社区描述
.NET技术交流专区
javascript云原生 企业社区
社区管理员
  • ASP.NET
  • .Net开发者社区
  • R小R
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告

.NET 社区是一个围绕开源 .NET 的开放、热情、创新、包容的技术社区。社区致力于为广大 .NET 爱好者提供一个良好的知识共享、协同互助的 .NET 技术交流环境。我们尊重不同意见,支持健康理性的辩论和互动,反对歧视和攻击。

希望和大家一起共同营造一个活跃、友好的社区氛围。

试试用AI创作助手写篇文章吧