?? md5suanfa.txt
字號:
MD5的全稱是Message-Digest Algorithm 5(信息-摘要算法),在90年代初由Mit Laboratory for Computer Science和Rsa data security inc的Ronald l. rivest開發(fā)出來,經(jīng)md2、md3和md4發(fā)展而來。它的作用是讓大容量信息在用數(shù)字簽名軟件簽署私人密匙前被"壓縮"成一種保密的格式(就是把一個任意長度的字節(jié)串變換成一定長的大整數(shù))。不管是md2、md4還是md5,它們都需要獲得一個隨機長度的信息並產(chǎn)生一個128位的信息摘要。
加密哈希函數(shù)將任意長度的二進(jìn)制字符串映射為固定長度的小型二進(jìn)制字符串。加密哈希函數(shù)有這樣一個屬性:在計算上不大可能找到散列為相同的值的兩個不同的輸入;也就是說,兩組數(shù)據(jù)的哈希值僅在對應(yīng)的數(shù)據(jù)也匹配時才會匹配。數(shù)據(jù)的少量更改會在哈希值中產(chǎn)生不可預(yù)知的大量更改。所以你很難從加密後的文字中找到蛛絲馬跡。
SHA1的全稱是Secure Hash Algorithm(安全哈希算法)
MD5 算法的哈希值大小為 128 位。而SHA1 算法的哈希值大小為 160 位。兩種算法都是不可逆。
雖說2004年8月17日的美國加州聖巴巴拉的國際密碼學(xué)會議(Crypto'2004)上,來自中國山東大學(xué)的王小雲(yún)教授做了破譯MD5、HAVAL-128、 MD4和RIPEMD算法的報告,公佈了MD系列算法的破解結(jié)果。宣告了固若金湯的世界通行密碼標(biāo)準(zhǔn)MD5的堡壘轟然倒塌,引發(fā)了密碼學(xué)界的軒然大波。但是我覺得對於我們做普通的軟件來說,這個加密安全程度已經(jīng)足夠使用了。
我們平常用的最多的無非就是加密用戶密碼,把加密好的密碼存儲到數(shù)據(jù)庫中,進(jìn)行密碼比較的時候,把用戶輸入的密碼再進(jìn)行加密,然後與數(shù)據(jù)庫中的密文進(jìn)行比較。至於asp.net類中是如何實現(xiàn)加密算法的,這個我們不需要關(guān)心,會用就行了。
下面就是Asp.net中幾種加密方法。加密算法有兩種,也就是上面提到的MD5和SHA1,這裡我舉的例子是以MD5為例,SHA1大致相同,只是使用的類不一樣。
MD5 相關(guān)類:
System.Security.Cryptography.MD5
System.Security.Cryptography.MD5CryptoServiceProvider()
System.Web.Security.FormsAuthentication.HashPasswordForStoringInConfigFile(strSource, "MD5")
SHA1相關(guān)類:
System.Security.Cryptography.SHA1
System.Security.Cryptography.SHA1CryptoServiceProvider()
System.Web.Security.FormsAuthentication.HashPasswordForStoringInConfigFile(strSource, "SHA1")
方法如下:(用的vs2005)
1/**////
2 /// 方法一:通過使用 new 運算符創(chuàng)建對像
3 ///
4 /// 需要加密的明文
5 /// 返回16位加密結(jié)果,該結(jié)果取32位加密結(jié)果的第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 //獲取密文字節(jié)數(shù)組
12 byte[] bytResult = md5.ComputeHash(System.Text.Encoding.Default.GetBytes(strSource));
13
14 //轉(zhuǎn)換成字符串,並取9到25位
15 string strResult = BitConverter.ToString(bytResult, 4, 8);
16 //轉(zhuǎn)換成字符串,32位
17 //string strResult = BitConverter.ToString(bytResult);
18
19 //BitConverter轉(zhuǎn)換出來的字符串會在每個字符中間產(chǎn)生一個分隔符,需要去除掉
20 strResult = strResult.Replace("-", "");
21 return strResult;
22 }
23
24 /**////
25 /// 方法二:通過調(diào)用特定加密算法的抽像類上的 Create 方法,創(chuàng)建實現(xiàn)特定加密算法的對象。
26 ///
27 /// 需要加密的明文
28 /// 返回32位加密結(jié)果
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();
?? 快捷鍵說明
復(fù)制代碼
Ctrl + C
搜索代碼
Ctrl + F
全屏模式
F11
切換主題
Ctrl + Shift + D
顯示快捷鍵
?
增大字號
Ctrl + =
減小字號
Ctrl + -