最近開發一個需求,涉及獲取服務端https證書。通常進行https調用咱們都不太關心底層細節,直接使用WebClient或者HttpWebRequest來發送請求,這兩種方法都沒法獲取證書信息,須要用到ServicePoint,這個類用於提供HTTP鏈接的管理。c#
寫個Demo,拿新浪首頁試一下:服務器
using System; using System.Net; using System.Security.Cryptography.X509Certificates; namespace GetServerCertificateDemo { class Program { static void Main(string[] args) { //用WebClient訪問新浪首頁 var http = new WebClient(); var uri = new Uri("https://www.sina.com.cn"); http.DownloadString(uri); //經過Uri獲取ServicePoint var servicePoint = ServicePointManager.FindServicePoint(uri); //取服務端證書,X509Certificate格式,轉一下 var serverCert = new X509Certificate2(servicePoint.Certificate); Console.WriteLine("頒發給:{0}", serverCert.Subject); Console.WriteLine("頒發者:{0}", serverCert.Issuer); Console.WriteLine("序列號:{0}", serverCert.SerialNumber); Console.WriteLine("指 紋:{0}", serverCert.Thumbprint); Console.WriteLine("起 始:{0}", serverCert.NotBefore); Console.WriteLine("過 期:{0}", serverCert.NotAfter); } } }
運行看效果:ide
上半部分是程序運行結果,下面是用Firefox查看的服務端證書信息,各項信息都能對應上。若是程序中涉及多個不一樣服務器的訪問也不要緊,關鍵在於根據Uri獲取ServicePoint,而後取到的證書就是此服務器的了。spa