国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > .NET > 正文

ASP.Net用MD5和SHA1加密的幾種方法_.Net教程

2024-07-10 12:50:36
字體:
來源:轉載
供稿:網友

推薦:asp.net中生成縮略圖并添加版權
//定義image類的對象Drawing.Image image,newimage;//圖片路徑protected string imagePath;//圖片類型protected string imageType;//圖片名稱protected string imageName;//提供一個

首先簡單介紹一下MD5和SHA1:

MD5的全稱是Message-Digest Algorithm 5(信息-摘要算法),在90年代初由Mit Laboratory for Computer Science和Rsa data security inc的Ronald l. rivest開發出來,經md2、md3和md4發展而來。它的作用是讓大容量信息在用數字簽名軟件簽署私人密匙前被"壓縮"成一種保密的格式(就是把一個任意長度的字節串變換成一定長的大整數)。不管是md2、md4還是md5,它們都需要獲得一個隨機長度的信息并產生一個128位的信息摘要。

加密哈希函數將任意長度的二進制字符串映射為固定長度的小型二進制字符串。加密哈希函數有這樣一個屬性:在計算上不大可能找到散列為相同的值的兩個不同的輸入;也就是說,兩組數據的哈希值僅在對應的數據也匹配時才會匹配。數據的少量更改會在哈希值中產生不可預知的大量更改。所以你很難從加密后的文字中找到蛛絲馬跡。

SHA1的全稱是Secure Hash Algorithm(安全哈希算法)

MD5 算法的哈希值大小為 128 位。而SHA1 算法的哈希值大小為 160 位。兩種算法都是不可逆。

雖說2004年8月17日的美國加州圣巴巴拉的國際密碼學會議(Crypto’2004)上,來自中國山東大學的王小云教授做了破譯MD5、HAVAL-128、 MD4和RIPEMD算法的報告,公布了MD系列算法的破解結果。宣告了固若金湯的世界通行密碼標準MD5的堡壘轟然倒塌,引發了密碼學界的軒然大波。但是我覺得對于我們做普通的軟件來說,這個加密安全程度已經足夠使用了。

我們平常用的最多的無非就是加密用戶密碼,把加密好的密碼存儲到數據庫中,進行密碼比較的時候,把用戶輸入的密碼再進行加密,然后與數據庫中的密文進行比較。至于asp.net類中是如何實現加密算法的,這個我們不需要關心,會用就行了。

下面就是Asp.net中幾種加密方法。加密算法有兩種,也就是上面提到的MD5和SHA1,這里我舉的例子是以MD5為例,SHA1大致相同,只是使用的類不一樣。

MD5 相關類:

System.Security.Cryptography.MD5

System.Security.Cryptography.MD5CryptoServiceProvider()

System.Web.Security.FormsAuthentication.HashPasswordForStoringInConfigFile(strSource, "MD5")

SHA1相關類:

System.Security.Cryptography.SHA1

System.Security.Cryptography.SHA1CryptoServiceProvider()

System.Web.Security.FormsAuthentication.HashPasswordForStoringInConfigFile(strSource, "SHA1")

方法如下:(用的vs2005)

1/**////
2 /// 方法一:通過使用 new 運算符創建對象
3 ///
4 /// 需要加密的明文
5 /// 返回16位加密結果,該結果取32位加密結果的第9位到25位
6 public string Get_MD5_Method1(string strSource)
7 {
8 //new
9 System.Security.Cryptography.MD5 md5 = new System.Security.Cryptography.MD5CryptoServiceProvider();
10
11 //獲取密文字節數組
12 byte[] bytResult = md5.ComputeHash(System.Text.Encoding.Default.GetBytes(strSource));
13
14 //轉換成字符串,并取9到25位
15 string strResult = BitConverter.ToString(bytResult, 4, 8);
16 //轉換成字符串,32位
17 //string strResult = BitConverter.ToString(bytResult);
18
19 //BitConverter轉換出來的字符串會在每個字符中間產生一個分隔符,需要去除掉
20 strResult = strResult.Replace("-", "");
21 return strResult;
22 }
23
24 /**////
25 /// 方法二:通過調用特定加密算法的抽象類上的 Create 方法,創建實現特定加密算法的對象。
26 ///
27 /// 需要加密的明文
28 /// 返回32位加密結果
29 public string Get_MD5_Method2(string strSource)
30 {
31 string strResult = "";
32
33 //Create
34 System.Security.Cryptography.MD5 md5 = System.Security.Cryptography.MD5.Create();
35
36 //注意編碼UTF8、UTF7、Unicode等的選擇 
37 byte[] bytResult = md5.ComputeHash(System.Text.Encoding.UTF8.GetBytes(strSource));
38
39 //字節類型的數組轉換為字符串
40 for (int i = 0; i < bytResult.Length; i )
41 {
42 //16進制轉換
43 strResult = strResult bytResult[i].ToString("X");
44 }
45 return strResult;
46 }
47
48 /**////
49 /// 方法三:直接使用HashPasswordForStoringInConfigFile生成
50 ///
51 /// 需要加密的明文
52 /// 返回32位加密結果
53 public string Get_MD5_Method3(string strSource)
54 {
55 return System.Web.Security.FormsAuthentication.HashPasswordForStoringInConfigFile(strSource, "MD5");
56 }

這些加密函數都是在服務器端執行,也就是說,當用戶輸入密碼后,從客戶端到服務器端傳輸時,用戶的密碼沒有任何保護,很危險。銀行的做法是在客戶端安裝ActiveX控件,在客戶端就把一些重要信息進行加密,再發送。這個偶就不會拉,很希望能學習學習做這種ActiveX控件。

分享:ASP.NET 設計中的 N 個技巧
asp.net中DataGrid雙行跨列表頭設計心得! 一、DataGrid的屬性設置   1. AllowPaging: true   2. PageStyle->Position: TopAndBottom 3. 可選:PageStyle->HorizonAlign: Center(

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 黄龙县| 汾西县| 浦北县| 孝义市| 桐柏县| 安平县| 湛江市| 卢龙县| 荣成市| 武汉市| 通河县| 福清市| 磐石市| 芮城县| 宁晋县| 曲周县| 聂拉木县| 广州市| 平顶山市| 星座| 天全县| 清水河县| 东辽县| 许昌市| 克拉玛依市| 达州市| 神农架林区| 紫云| 饶阳县| 大埔县| 和平县| 井冈山市| 无棣县| 临江市| 巴马| 西乌珠穆沁旗| 河池市| 临洮县| 嘉定区| 南安市| 剑川县|