C#中实现https的双向认证
2012-12-19 15:25
411 查看
1.
把浏览器中的证书导出为cer文件。
2. 代码如下:
把浏览器中的证书导出为cer文件。
2. 代码如下:
using System; using System.Net; using System.IO; using System.Security.Cryptography.X509Certificates; using System.Text; using System.Net.Security; public partial class About : System.Web.UI.Page { protected void Page_Load(object sender, EventArgs e) { // string url = "https://192.168.6.120/"; ServicePointManager.ServerCertificateValidationCallback = RemoteCertificateValidationCallback; //Uri uri = new Uri("https://www.baifubao.com/"); Uri uri = new Uri("https://192.168.6.120/"); HttpWebRequest request = (HttpWebRequest)WebRequest.Create(uri); X509Certificate cer = new X509Certificate("F:\\csharp2.cer"); request.ClientCertificates.Add(cer); HttpWebResponse response = (HttpWebResponse)request.GetResponse(); string encoding = response.ContentEncoding; if (encoding == null || encoding.Length < 1) { encoding = "UTF-8"; //默认编码 } StreamReader reader = new StreamReader(response.GetResponseStream(), Encoding.GetEncoding(encoding)); Response.Write(reader.ReadToEnd()); //Console.Write(reader.ReadToEnd()); response.Close(); } public static bool RemoteCertificateValidationCallback(object sender, X509Certificate certificate, X509Chain chain, SslPolicyErrors sslPolicyErrors) { if (sslPolicyErrors == SslPolicyErrors.None) return true; return false; } }
相关文章推荐
- C#中实现https的双向认证
- ASIHTTPRequest实现https双向认证请求
- Android5.0以下WebView实现访问Https双向认证网页
- https研究(四)用Let's Encrypt实现Https双向认证)
- ASIHTTPRequest实现https双向认证请求
- nginx与ios实现https双向认证
- 实现https双向认证,并去除commonName的校验
- ASIHTTPRequest实现https双向认证请求
- CXF实现HTTPS双向认证
- Tomcat实现https双向认证功能
- Android HTTPS 自制证书实现双向认证(OkHttp + Retrofit + Rxjava)
- nginx+openssl+https 实现双向认证所遇到的坑
- java实现https双向认证
- ASIHTTPRequest实现https双向认证请求
- ASIHTTPRequest实现https双向认证请求
- 自签SSL证书实现Nginx配置https双向认证
- java https双向认证实现
- java中实现https双向认证
- Android HTTPS 自制证书实现双向认证(OkHttp + Retrofit + Rxjava)
- php实现https(tls/ssl)双向认证