C# 使用rsa证书加密,服务器拒绝访问
我使用的rsa证书加密算法,在本地测试,读取加密都是没有问题的额,在windows 2003上面就不行了,服务器拒绝访问,而且我把所有的权限都给了,。也是不行,
求哪位大神帮个忙。
同时咨询下,可以不可以,把证书安装到电脑里面进行调用,而不是调用本地的证书文件。
一下是我们的加密算法:
byte[] bytes = System.Text.Encoding.UTF8.GetBytes(signMsgVal);
X509Certificate2 cert = new X509Certificate2(HttpContext.Current.Server.MapPath("wanfrsa.pfx"), "123456", X509KeyStorageFlags.MachineKeySet);
RSACryptoServiceProvider rsapri = (RSACryptoServiceProvider)cert.PrivateKey;
RSAPKCS1SignatureFormatter f = new RSAPKCS1SignatureFormatter(rsapri);
byte[] result;
f.SetHashAlgorithm("SHA1");
SHA1CryptoServiceProvider sha = new SHA1CryptoServiceProvider();
result = sha.ComputeHash(bytes);
signMsg = System.Convert.ToBase64String(f.CreateSignature(result)).ToString();
------解决方案--------------------看到要沉了,赶紧帮忙顶下
------解决方案--------------------HttpContext.Current.Server.MapPath("wanfrsa.pfx")
这个路径的权限在确定下,
------解决方案--------------------http://support.microsoft.com/kb/938397 把这个kb在2003上安装上。
具体解释在这:http://blogs.technet.com/b/pki/archive/2010/09/30/sha2-and-windows.aspx
主要是说windows2003没有加入SHA256,需要用补丁加进去。
------解决方案--------------------