成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

.NET中如何操作數字證書詳解

開發 后端
本文將討論的是.NET中如何操作數字證書,包括如何生成證書、編程操作證書、創建發行者證書等等步驟。

.NET為我們提供了操作數字證書的兩個主要的類,分為為:

System.Security.Cryptography.X509Certificates.X509Certificate2類, 每個這個類的實例可以表示一個證書;

System.Security.Cryptography.X509Certificates.X509Store類,可以對保存在計算機安全區域內的證書進行add/remove/get操作。

另外我們可以使用System.Security.Cryptography.X509Certificates.X509Certificate2UI類來顯示證書消息的對話框,它就是在IE中的證書查看器的.NE實現。

生成證書

在介紹以上類的使用方法之前,我們先要擁有一個數字證書,獲取數字證書有三種方法,一是從CA機構申請,二是自己搭建服務器發布證書,三是使用makecert.exe來生成一個證書文件。這里我們使用makecert.exe來生成一個證書文件,用來測試。啟動VS2010的命令行,輸入對應參數,生成名為TestCertificates的證書文件。如圖6-28所示。

生成證書

圖6-28 生成證書

makecert.exe的參數讀者可以查看幫助,這里只解釋圖6-28中的參數。

參數說明:

-sr CurrentUser:指定主題的證書存儲位置。Location 可以是 currentuser(默認值)或 localmachine

-ss MyTestContainer:指定主題的證書存儲名稱,輸出證書即存儲在那里。

-n CN=TestCert:指定主題的證書名稱。此名稱必須符合 X.500 標準。最簡單的方法是在雙引號中指定此名稱,并加上前綴 CN=;例如,"CN=myName"。

-sky exchange:指定頒發者的密鑰類型,必須是 signature、exchange 或一個表示提供程序類型的整數。默認情況下,可傳入 1 表示交換密鑰,傳入 2 表示簽名密鑰。

-pe:將所生成的私鑰標記為可導出。這樣可將私鑰包括在證書中。

生成的密鑰文件被保存在了我們指定的MyTestContainer中,但到哪去查看我們的證書呢?Windows沒有給我們準備好直接的管理證書的入口,但我們可以在MMC控制臺自行添加。

  1. 開始  運行  MMC,打開一個空的MMC控制臺。
  2. 在控制臺菜單,文件  添加/刪除管理單元  添加按鈕  選"證書"  添加  選"我的用戶賬戶"  關閉  確定
  3. 在控制臺菜單,文件  添加/刪除管理單元  添加按鈕  選"證書"  添加  選"計算機賬戶"  關閉  確定

如圖6-29,我們可以查看兩個賬戶的證書管理,在我的賬戶中可以看到MyTestContainer下的證書TestCert。

在MMC控制臺查看和管理證書

圖6-29 在MMC控制臺查看和管理證書

當然我們也可以將證書文件保存為文件,如圖6-30所示。

將證書保存為文件

圖6-30 將證書保存為文件

打開E盤,可以看到生成的證書文件。如圖6-31所示。

生成的證書文件

圖6-31 生成的證書文件

將證書保存為文件時,我們有三種選擇:

  1. 帶有私鑰的證書

    由Public Key Cryptography Standards #12,PKCS#12標準定義,包含了公鑰和私鑰的二進制格式的證書形式,以pfx作為證書文件后綴名。

  2. 二進制編碼的證書

    證書中沒有私鑰,DER 編碼二進制格式的證書文件,以cer作為證書文件后綴名。

  3. Base64編碼的證書

    證書中沒有私鑰,BASE64 編碼格式的證書文件,也是以cer作為證書文件后綴名。

右鍵單擊本地的證書文件,我們可以看到安裝選項,可以把該證書文件安裝到證書存儲區。也可在MMC的證書管理臺上執行導出任務將存儲區的證書導出為文件。這里就不再演示了,讀者可以自行實踐。

編程操作證書

我們可以通過編程的方式操作操作本地的證書文件和在存儲區中的證書。我們以剛才保存在E盤的test.cer文件為例,講解如何讀取本地的證書文件,并將它添加到存儲區中。先看代碼清單6-17。

代碼清單 6-17 操作本地證書文件

  1. class OperCert  
  2. {  
  3. internal static byte[] ReadFile(string fileName)  
  4. {  
  5. FileStream f = new FileStream(fileName, FileMode.Open, FileAccess.Read);  
  6. int size = (int)f.Length;  
  7. byte[] data = new byte[size];  
  8. size = f.Read(data, 0, size);  
  9. f.Close();  
  10. return data;  
  11. }  
  12. static void Main(string[] args)  
  13. {  
  14. try 
  15. {  
  16. X509Certificate2 x509 = new X509Certificate2();  
  17. byte[] rawData = ReadFile(@"e:\test.cer");  
  18. x509.Import(rawData);  
  19. Console.WriteLine("{0}Subject: {1}{0}", Environment.NewLine, x509.Subject);  
  20. Console.WriteLine("{0}Issuer: {1}{0}", Environment.NewLine, x509.Issuer);  
  21. Console.WriteLine("{0}Version: {1}{0}", Environment.NewLine, x509.Version);  
  22. Console.WriteLine("{0}Valid Date: {1}{0}", Environment.NewLine, x509.NotBefore);  
  23. Console.WriteLine("{0}Expiry Date: {1}{0}", Environment.NewLine, x509.NotAfter);  
  24. Console.WriteLine("{0}Thumbprint: {1}{0}", Environment.NewLine, x509.Thumbprint);  
  25. Console.WriteLine("{0}Serial Number: {1}{0}", Environment.NewLine, x509.SerialNumber);  
  26. Console.WriteLine("{0}Friendly Name: {1}{0}", Environment.NewLine, x509.PublicKey.Oid.FriendlyName);  
  27. Console.WriteLine("{0}Public Key Format: {1}{0}", Environment.NewLine, x509.PublicKey.EncodedKeyValue.Format(true));  
  28. Console.WriteLine("{0}Raw Data Length: {1}{0}", Environment.NewLine, x509.RawData.Length);  
  29. Console.WriteLine("{0}Certificate to string: {1}{0}", Environment.NewLine, x509.ToString(true));  
  30. Console.WriteLine("{0}Certificate to XML String: {1}{0}", Environment.NewLine, x509.PublicKey.Key.ToXmlString(false));  
  31. X509Store store = new X509Store();  
  32. store.Open(OpenFlags.MaxAllowed);  
  33. store.Add(x509);  
  34. store.Close();  
  35. }  
  36. catch (Exception e)  
  37. {  
  38. Console.WriteLine("Error:"+e.Message);  
  39. }  
  40. }  

代碼清單6-17演示了如何讀取本地證書文件的方法。靜態方法ReadFile用來從本地磁盤中讀取證書文件到byte數組中。主要的操作都在Main方法中。X509Certificate2 x509 = new X509Certificate2()一句使用無參數的構造函數初始化X509Certificate2類的實例x509。然后我們使用x509.Import(rawData)語句將byte數組導入到當前證書實例。接下來是輸出該證書的信息。

輸出信息之后,我們看下面的四行代碼:

 

  1. X509Store store = new X509Store();  
  2. store.Open(OpenFlags.MaxAllowed);  
  3. store.Add(x509);  
  4. store.Close(); 

 

首先我們初始化一個X509Store類的實例store,然后使用Open方法打開存儲區,添加上面讀取的證書到存儲區。

X509Certificate2一共提供了14個構造函數供我們使用,這里就不一一介紹了。我們也可以通過X509Certificate2類的構造函數直接導入本地的證書文件,可以使用代碼清單6-18所示的方式。

代碼清單6-18 使用構造函數導入證書文件

 

  1. X509Certificate2 myX509Certificate2 = new X509Certificate2(  
  2. @"e:\MyTestCert.pfx"//證書路徑  
  3. "password"//證書的私鑰保護密碼  
  4. X509KeyStorageFlags.Exportable //表示此證書的私鑰以后還可以導出  
  5. ); 

 

代碼清單6-18給出了如何導入帶私鑰保護密碼的證書的方法。X509KeyStorageFlags 枚舉用來標識X.509 證書的私鑰導出到何處以及如何導出。該枚舉的成員說明如表6-1所示。

表6-1 X509KeyStorageFlags 枚舉說明


成員名稱

說明

DefaultKeySet

使用默認的密鑰集。用戶密鑰集通常為默認值。

UserKeySet

私鑰存儲在當前用戶存儲區而不是本地計算機存儲區。既使證書指定密鑰應存儲在本地計算機存儲區,私鑰也會存儲到當前用戶存儲區。

MachineKeySet

私鑰存儲在本地計算機存儲區而不是當前用戶存儲區。

Exportable

導入的密鑰被標記為可導出。

UserProtected

通過對話框或其他方法,通知用戶密鑰被訪問。使用的加密服務提供程序 (CSP) 定義確切的行為。

PersistKeySet

導入證書時會保存與 PFX 文件關聯的密鑰。

那么如何操作存儲區中的證書呢,可以使用代碼清單6-19的方式。

代碼清單6-19 操作存儲區中的證書

 

  1. X509Store store = new X509Store(StoreName.My, StoreLocation.CurrentUser);  
  2. store.Open(OpenFlags.ReadOnly);  
  3. //輪詢存儲區中的所有證書  
  4. foreach(X509Certificate2 myX509Certificate2 in store.Certificates)  
  5. {  
  6. //將證書的名稱跟要導出的證書MyTestCert比較,找到要導出的證書  
  7. if (myX509Certificate2.Subject == "CN=TestCert")  
  8. {  
  9. //證書導出到byte[]中,password為私鑰保護密碼  
  10. byte[] CertByte = myX509Certificate2.Export(X509ContentType.Pfx,"password");  
  11. //將證書的字節流寫入到證書文件  
  12. FileStream fStream = new FileStream(  
  13. @"C:\Samples\PartnerAEncryptMsg\MyTestCert_Exp.pfx",  
  14. FileMode.Create,  
  15. FileAccess.Write);  
  16. fStream.Write(CertByte, 0, CertByte.Length);  
  17. fStream.Close();  
  18. }  
  19. }  
  20. store.Close(); 

 

代碼清單6-19首先聲明X509Store類的實例store,使用了兩個參數的構造函數,第一個參數是存儲容器的名稱,StoreName枚舉只能枚舉系統默認的存儲區名稱。第二個參數是StoreLocation枚舉,用來標識是本機證書還是當前用戶證書。導出容器證書使用的是Export方法。第一個參數X509ContentType.Pfx表示要導出為含有私鑰的pfx證書形式,第二個參數為私鑰保護密碼。如果要導出為不含私鑰的cer證書,第一個參數使用X509ContentType.Cert,表示導出為不含私鑰的cer證書,也就不需要密碼了。

創建發行者證書

發行者證書是驗證發行者可靠性的證書文件,保護證書發行者的簽名。我們可以從證書頒發機構獲得該文件。做為程序測試,我們可以使用Cert2spc.exe來生成發行者證書。從命令行啟動該程序,如圖6-32所示。

生成SPC文件

圖6-32 生成SPC文件

如圖6-32,我們使用Cert2spc.exe以test.cer為參數生成目標為tset.spc的發行者證書,如果存在多個證書文件,可以作為參數以空格隔開生成統一的發行者證書。

使用證書對文件簽名

簽名工具 (SignTool.exe) 是一個命令行工具,用于對文件進行數字簽名,驗證文件或時間戳文件中的簽名。我們可以對cab文件、dll文件或者其他文件進行簽名,從互聯網訪問這些文件的時候就需要安裝和驗證證書。該工具詳細的說明讀者可以從MSDN上找到,我就不在重復了。

原文標題:在.NET中操作數字證書(新手教程)  

鏈接:http://www.cnblogs.com/xuanhun/archive/2010/06/20/1761560.html

【編輯推薦】

  1. 使用ASP.NET 4的自動啟動特性
  2. 詳解.NET 4.0并行計算支持歷史
  3. 詳讀.NET 4.0環境配置
  4. 詳解.NET 4.0中異常處理方面的新特性
  5. 三方面詮釋.NET 4.0的新特性

 

責任編輯:彭凡 來源: 博客園
相關推薦

2009-12-28 16:57:40

ADO .NET 類

2020-11-16 08:56:02

Python

2009-08-04 14:52:33

Visual Web ASP.NET

2009-08-14 13:58:43

數字證書通信加密身份驗證

2011-09-13 09:37:38

2016-05-11 10:09:49

數據層代碼FastQuery

2011-07-05 10:27:06

MySQL數據庫檢索排序

2011-07-01 13:42:24

QT 數據庫

2010-01-26 14:38:08

Android數字證書

2009-09-15 09:50:07

Linq操作數據庫

2020-03-12 10:41:35

數字簽名加密證書劫持

2016-11-10 23:51:41

2013-06-28 10:24:31

2022-10-09 15:41:54

Python數據庫

2010-09-02 21:10:13

2020-03-11 20:11:06

電腦騷操作AMD

2009-07-07 09:24:37

LINQ檢索

2024-11-28 09:43:54

2011-04-19 10:20:09

數據庫

2023-09-27 07:49:23

點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 中文字幕成人免费视频 | 日韩视频一区在线观看 | 日韩成人av在线 | 欧美一区视频 | 成人午夜免费在线视频 | 国产欧美精品一区二区三区 | 欧美在线观看一区二区 | 暖暖成人免费视频 | 中文字幕国产 | 中文字幕亚洲区一区二 | 亚洲区一 | 日本涩涩视频 | 91夜色在线观看 | 亚洲精品99 | 成人免费av | 91在线网站 | 欧美一级片中文字幕 | 91国在线高清视频 | 欧美视频成人 | 国产目拍亚洲精品99久久精品 | 91av精品 | 日本一区二区不卡 | 少妇一级淫片aaaaaaaaa | 一区二区在线不卡 | 欧美一级片在线看 | 成人在线中文字幕 | 北条麻妃99精品青青久久 | 日韩欧美1区2区 | 午夜一级黄色片 | 国产精品日韩一区 | 99精彩视频 | 国产成都精品91一区二区三 | 欧美日产国产成人免费图片 | 成人精品一区亚洲午夜久久久 | 亚洲欧美一区二区三区在线 | 殴美黄色录像 | 中文字幕一区二区三区乱码图片 | 九九伦理片 | 夜夜爽夜夜操 | 国产成人精品在线播放 | 国产在线精品一区二区 |