C#中实现https的双向认证

1.  把浏览器中的证书导出为cer文件。

2.   代码如下:

  1. using System;  
  2. using System.Net;  
  3. using System.IO;  
  4. using System.Security.Cryptography.X509Certificates;  
  5. using System.Text;  
  6. using System.Net.Security;  
  7.   
  8. public partial class About : System.Web.UI.Page  
  9. {  
  10.     protected void Page_Load(object sender, EventArgs e)  
  11.     {  
  12.        // string url = "https://192.168.6.120/";  
  13.         ServicePointManager.ServerCertificateValidationCallback = RemoteCertificateValidationCallback;  
  14.         //Uri uri = new Uri("https://www.baifubao.com/");  
  15.   
  16.   
  17.         Uri uri = new Uri("https://192.168.6.120/");  
  18.         HttpWebRequest request = (HttpWebRequest)WebRequest.Create(uri);  
  19.         X509Certificate cer = new X509Certificate("F:\\csharp2.cer");  
  20.         request.ClientCertificates.Add(cer);  
  21.   
  22.         HttpWebResponse response = (HttpWebResponse)request.GetResponse();  
  23.         string encoding = response.ContentEncoding;  
  24.         if (encoding == null || encoding.Length < 1)  
  25.         {  
  26.             encoding = "UTF-8"; //默认编码  
  27.         }  
  28.         StreamReader reader = new StreamReader(response.GetResponseStream(), Encoding.GetEncoding(encoding));  
  29.         Response.Write(reader.ReadToEnd());  
  30.         //Console.Write(reader.ReadToEnd());  
  31.         response.Close();   
  32.     }  
  33.     public static bool RemoteCertificateValidationCallback(object sender, X509Certificate certificate, X509Chain chain, SslPolicyErrors sslPolicyErrors)  
  34.     {  
  35.         if (sslPolicyErrors == SslPolicyErrors.None)  
  36.             return true;  
  37.         return false;  
  38.     }  
posted @ 2017-02-24 09:00  zklve2  阅读(7347)  评论(0编辑  收藏  举报