本地调试没有问题,也导入了证书,但是服务器才出现的错误。
解决办法:
1.首先先确保服务器导入了证书。
使用MMC控制台导入或者双击.p12证书导入。
2.去下载微软官方WinHttpCertCfg.exe ,放到服务器安装。
默认是安装到:C:\Program Files (x86)\Windows Resource Kits\Tools
3.打开cmd,切记一定要右键以管理员身份运行!
不然后续执行命令会报错误:
Error: Unable to update security info for key container
4.cmd 到 WinHttpCertCfg.exe的安装目录。命令:
CD /D C:\Program Files (x86)\Windows Resource Kits\Tools
5.进入mmc》个人证书》查看证书(证书导入默认名称是商户号)》使用者;一般是微信商户的主体名称。
6.继续在cmd分别键入以下命令:(公司名称替换成上一步查到的名称)
winhttpcertcfg.exe -g -c LOCAL_MACHINE\MY -s "公司名称" -a "NETWORKSERVICE"
//这个在win2016好像是没有这个账户的,报错可以忽略。博主是只用到第一、第三行就可以了。
winhttpcertcfg.exe -g -c LOCAL_MACHINE\MY -s "公司名称" -a "ASPNET"
winhttpcertcfg.exe -g -c LOCAL_MACHINE\MY -s "公司名称" -a "Authenticated Users"
正常成功会提示:
7.代码中使用X509Certificate替换X509Certificate2。
public static string Post(string xml, string url, bool isUseCert, int timeout = 20)
{
System.GC.Collect();//垃圾回收,回收没有正常关闭的http连接
string result = "";//返回结果
HttpWebRequest request = null;
HttpWebResponse response = null;
Stream reqStream = null;
try
{
//设置最大连接数
ServicePointManager.DefaultConnectionLimit = 200;
/***************************************************************
* 下面设置HttpWebRequest的相关属性
* ************************************************************/
request = (HttpWebRequest)WebRequest.Create(url);
//request.UserAgent = USER_AGENT;
request.Method = "POST";
request.Timeout = timeout * 1000;
//设置代理服务器
//WebProxy proxy = new WebProxy(); //定义一个网关对象
//proxy.Address = new Uri(WxPayConfig.PROXY_URL); //网关服务器端口:端口
//request.Proxy = proxy;
//设置POST的数据类型和长度
request.ContentType = "text/xml";
byte[] data = System.Text.Encoding.UTF8.GetBytes(xml);
request.ContentLength = data.Length;
//是否使用证书
if (isUseCert)
{
//X509Certificate2改成X509Certificate
X509Certificate cert = new X509Certificate(WxPayConfig.GetSSlCertPath(), WxPayConfig.GetSSlCertPassword());
request.ClientCertificates.Add(cert);
}
//往服务器写入数据
reqStream = request.GetRequestStream();
reqStream.Write(data, 0, data.Length);
reqStream.Close();
//获取服务端返回
response = (HttpWebResponse)request.GetResponse();
//获取服务端返回数据
StreamReader sr = new StreamReader(response.GetResponseStream(), Encoding.UTF8);
result = sr.ReadToEnd().Trim();
sr.Close();
}
catch (Exception e)
{
throw;
}
finally
{
//关闭连接和流
if (response != null)
{
response.Close();
}
if (request != null)
{
request.Abort();
}
}
return result;
}
参考来源资料:
https://blog.csdn.net/weisubao/article/details/80339999