ASP.NET使用X509Certificate2出現(xiàn)一系列問(wèn)題的解決方法
在做微信支付退款的時(shí)候,由于需要使用到p12證書,結(jié)果就遇到一系列的坑。這里做個(gè)記錄方便以后查閱。
原先加載證書的代碼:
復(fù)制代碼 代碼如下:1 X509Certificate2 cert = new X509Certificate2(path + WxPayConfig.SSLCERT_PATH, WxPayConfig.SSLCERT_PASSWORD);2 Request.ClientCertificates.Add(cert);
在vs 上測(cè)試通過(guò)。但是部署到IIS上一直報(bào)這個(gè)問(wèn)題:
復(fù)制代碼 代碼如下:System.Security.Cryptography.CryptographicException: 系統(tǒng)找不到指定的文件。
詳細(xì)Stack Trace信息:
在 System.Security.Cryptography.CryptographicException.ThrowCryptographicException(Int32 hr)
在 System.Security.Cryptography.X509Certificates.X509Utils._LoadCertFromFile(String fileName, IntPtr password, UInt32 dwFlags, Boolean persistKeySet, SafeCertContextHandle& pCertCtx)
在 System.Security.Cryptography.X509Certificates.X509Certificate.LoadCertificateFromFile(String fileName, Object password, X509KeyStorageFlags keyStorageFlags)
在 System.Security.Cryptography.X509Certificates.X509Certificate2..ctor(String fileName, String password)
在 TenpayCore.HttpService.Post(TenpayException& tpEx, Byte[] xml, String url, Boolean isUseCert, Int32 timeout)。
反復(fù)測(cè)試之后,確認(rèn)不是代碼跟文件路徑的問(wèn)題。在查詢微軟的文檔后發(fā)現(xiàn)了相關(guān)說(shuō)明,指明了問(wèn)題所在,以下分享一下我的操作流程。
1.將證書安裝上去
點(diǎn)擊 [開始] -> [運(yùn)行] -> 鍵入[mmc] 進(jìn)入“控制臺(tái)”界面 -> 選擇[文件] -> [添加/刪除管理單元](Ctrl+M)
選擇 [證書] -> [計(jì)算機(jī)賬戶] -> [下一步] -> [完成]
選擇 [證書] -> [導(dǎo)入]
導(dǎo)入你的證書文件
2.授權(quán)證書
先安裝 winhttpcertcfg.exe 工具(Windows HTTP Services Certificate Configuration Tool)。安裝完成之后在該工具在C:Program Files (x86)Windows Resource KitsTools 或者C:Program FilesWindows Resource KitsTools 文件夾下。打開cmd鍵入命令:
復(fù)制代碼 代碼如下:winhttpcertcfg -g -c LOCAL_MACHINEMY -s "你的證書名稱" -a "你的iis賬號(hào)標(biāo)識(shí)"
-g 指令 就是授權(quán)
-c 是指證書所在的存儲(chǔ)區(qū)
另外,證書的名稱就是這個(gè),如圖所示 而不是其他什么東西,我就是搞錯(cuò)了,點(diǎn)擊這個(gè)證書的詳情取了里面的名稱,導(dǎo)致授權(quán)不成功。
而iis賬號(hào)標(biāo)識(shí),是指站點(diǎn)對(duì)應(yīng)的應(yīng)用程序池,高級(jí)設(shè)置里有標(biāo)識(shí)這個(gè)選項(xiàng)來(lái)選擇對(duì)應(yīng)的用戶。當(dāng)時(shí)我授權(quán)的標(biāo)識(shí)是Network Service,而應(yīng)用程序池中的標(biāo)識(shí)ApplicationPoolIdentity,結(jié)果導(dǎo)致我發(fā)起請(qǐng)求時(shí)出現(xiàn)了:
復(fù)制代碼 代碼如下:System.Net.WebException: 請(qǐng)求被中止: 未能創(chuàng)建 SSL/TLS 安全通道。
3.修改代碼
做完這些配置之后修改一下之前加載證書的代碼。
復(fù)制代碼 代碼如下:1 X509Store store = new X509Store("My", StoreLocation.LocalMachine);2 store.Open(OpenFlags.Readonly | OpenFlags.OpenExistingOnly);3 4 System.Security.Cryptography.X509Certificates.X509Certificate2 cert = 5 store.Certificates.Find(X509FindType.FindBySubjectName, "你的證書名稱", false)[0];
再測(cè)試一下,終于成功!
- ASP.NET 網(wǎng)站發(fā)布后出現(xiàn)“/”應(yīng)用程序中的服務(wù)器錯(cuò)誤
- 應(yīng)用程序池ASP.NET v4.0不能正常運(yùn)行的原因及解決方法
- asp.net中如何加入嵌入資源
- Asp.net mvc應(yīng)用程序生命周期
- ASP.NET 中獲取客戶端IP地址
- asp.net MVC5.0 路由調(diào)試工具-RouteDebugger用法
- asp.net mvc 客戶端中檢測(cè)到有潛在危險(xiǎn)的 Request.Path值
- asp.net4.0 aspnet_regiis.exe -i 執(zhí)行報(bào)錯(cuò)