System.Security.Cryptography.RSA.FromXmlString 系统找不到指定的文件和X509读取证书文件系统找不到指定的文件异常...

前言:

    最近公司增加服务器,在新增加的服务器中发现一些问题。

    1.应用程序在读取证书文件中出现“系统找不到指定的文件。”异常,但是已经确认证书文件存在。本地测试也可以读取,就在新增加的服务器上不可以。

    2.RSA加密过程中在 System.Security.Cryptography.RSA.FromXmlString()抛异常: System.Security.Cryptography.CryptographicException: 系统找不到指定的文件。

    解决方案:

    打开IIS设置,应用程序池--》找到自己的应用程序(网站名称)-->右键-->高级设置-->在进程模型区域,有个-用户加载配置文件-选择后面为true.这个问题就解决了。

    原理:

    .NET的RSA加密会加载密钥到密钥存储区,用户加载配置文件为false时,没有密钥存储区的访问权限。所以报“系统找不到指定的文件。”异常

 

 

 

 

    本文版权归作者 心灬无痕(博文地址:http://www.cnblogs.com/xinwuhen/)所有,欢迎转载和商用,请在文章页面明显位置给出原文链接并保留此段声明,否则保留追究法律责任的权利,其他事项,可留言咨询。

    

    

    

转载于:https://www.cnblogs.com/xinwuhen/p/8031638.html

这代码有那些控件:using System; using System.Security.Cryptography; using System.Text; using System.Windows.Forms; namespace RSASignatureVerification { public partial class Form1 : Form { public Form1() { InitializeComponent(); } private void btnSign_Click(object sender, EventArgs e) { try { // 生成RSA密钥对 RSACryptoServiceProvider rsa = new RSACryptoServiceProvider(); string privateKey = rsa.ToXmlString(true); string publicKey = rsa.ToXmlString(false); // 使用私钥对消息进行签名 byte[] data = Encoding.UTF8.GetBytes(txtMessage.Text); byte[] signature = SignData(data, privateKey); // 显示签名结果 txtSignature.Text = Convert.ToBase64String(signature); // 将私钥和公钥保存到文件中 SaveKeyToFile(privateKey, "privateKey.txt"); SaveKeyToFile(publicKey, "publicKey.txt"); } catch (Exception ex) { MessageBox.Show(ex.Message); } } private void btnVerify_Click(object sender, EventArgs e) { try { // 从文件读取公钥 string publicKey = LoadKeyFromFile("publicKey.txt"); // 使用公钥对签名进行验证 byte[] data = Encoding.UTF8.GetBytes(txtMessage.Text); byte[] signature = Convert.FromBase64String(txtSignature.Text); bool result = VerifyData(data, signature, publicKey); // 显示验证结果 if (result) { MessageBox.Show("签名验证成功"); } else { MessageBox.Show("签名验证失败"); } } catch (Exception ex) { MessageBox.Show(ex.Message); } } // 使用私钥对数据进行签名 private byte[] SignData(byte[] data, string privateKey) { RSACryptoServiceProvider rsa = new RSACryptoServiceProvider(); rsa.FromXmlString(privateKey); return rsa.SignData(data, new SHA256CryptoServiceProvider()); } // 使用公钥对签名进行验证 private bool VerifyData(byte[] data, byte[] signature, string publicKey) { RSACryptoServiceProvider rsa = new RSACryptoServiceProvider(); rsa.FromXmlString(publicKey); return rsa.VerifyData(data, new SHA256CryptoServiceProvider(), signature); } // 将密钥保存到文件中 private void SaveKeyToFile(string key, string fileName) { using (System.IO.StreamWriter sw = new System.IO.StreamWriter(fileName)) { sw.Write(key); } } // 从文件读取密钥 private string LoadKeyFromFile(string fileName) { using (System.IO.StreamReader sr = new System.IO.StreamReader(fileName)) { return sr.ReadToEnd(); } } } }
06-11
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值