ASP.NET中MD5與SHA1加密的幾種方法
更新時(shí)間:2010年04月06日 14:28:42 作者:
下面就是ASP.NET中幾種加密方法。加密算法有兩種,也就是上面提到的MD5和SHA1,這里我舉的例子是以MD5為例,SHA1大致相同,只是使用的類(lèi)不一樣。
MD5的全稱(chēng)是Message-Digest Algorithm 5(信息-摘要算法),在90年代初由Mit Laboratory for Computer Science和Rsa data security inc的Ronald l. rivest開(kāi)發(fā)出來(lái),經(jīng)md2、md3和md4發(fā)展而來(lái)。它的作用是讓大容量信息在用數(shù)字簽名軟件簽署私人密匙前被"壓縮"成一種保密的格式(就是把一個(gè)任意長(zhǎng)度的字節(jié)串變換成一定長(zhǎng)的大整數(shù))。不管是md2、md4還是md5,它們都需要獲得一個(gè)隨機(jī)長(zhǎng)度的信息并產(chǎn)生一個(gè)128位的信息摘要。
加密哈希函數(shù)將任意長(zhǎng)度的二進(jìn)制字符串映射為固定長(zhǎng)度的小型二進(jìn)制字符串。加密哈希函數(shù)有這樣一個(gè)屬性:在計(jì)算上不大可能找到散列為相同的值的兩個(gè)不同的輸入;也就是說(shuō),兩組數(shù)據(jù)的哈希值僅在對(duì)應(yīng)的數(shù)據(jù)也匹配時(shí)才會(huì)匹配。數(shù)據(jù)的少量更改會(huì)在哈希值中產(chǎn)生不可預(yù)知的大量更改。所以你很難從加密后的文字中找到蛛絲馬跡。
SHA1的全稱(chēng)是Secure Hash Algorithm(安全哈希算法)
MD5 算法的哈希值大小為128位。而SHA1 算法的哈希值大小為160位。兩種算法都是不可逆。
雖說(shuō)2004年8月17日的美國(guó)加州圣巴巴拉的國(guó)際密碼學(xué)會(huì)議(Crypto'2004)上,來(lái)自中國(guó)山東大學(xué)的王小云教授做了破譯MD5、HAVAL-128、 MD4和RIPEMD算法的報(bào)告,公布了MD系列算法的破解結(jié)果。宣告了固若金湯的世界通行密碼標(biāo)準(zhǔn)MD5的堡壘轟然倒塌,引發(fā)了密碼學(xué)界的軒然大波。但是我覺(jué)得對(duì)于我們做普通的軟件來(lái)說(shuō),這個(gè)加密安全程度已經(jīng)足夠使用了。
我們平常用的最多的無(wú)非就是加密用戶(hù)密碼,把加密好的密碼存儲(chǔ)到數(shù)據(jù)庫(kù)中,進(jìn)行密碼比較的時(shí)候,把用戶(hù)輸入的密碼再進(jìn)行加密,然后與數(shù)據(jù)庫(kù)中的密文進(jìn)行比較。至于ASP.net類(lèi)中是如何實(shí)現(xiàn)加密算法的,這個(gè)我們不需要關(guān)心,會(huì)用就行了。
下面就是ASP.NET中幾種加密方法。加密算法有兩種,也就是上面提到的MD5和SHA1,這里我舉的例子是以MD5為例,SHA1大致相同,只是使用的類(lèi)不一樣。
MD5 相關(guān)類(lèi):
System.Security.Cryptography.MD5
System.Security.Cryptography.MD5CryptoServiceProvider()
System.Web.Security.FormsAuthentication.HashPasswordForStoringInConfigFile(strSource, "MD5")
SHA1相關(guān)類(lèi):
System.Security.Cryptography.SHA1
System.Security.Cryptography.SHA1CryptoServiceProvider()
System.Web.Security.FormsAuthentication.HashPasswordForStoringInConfigFile(strSource, "SHA1")
方法如下:(用的vs2005)
/**//// <summary>
/// 方法一:通過(guò)使用 new 運(yùn)算符創(chuàng)建對(duì)象
/// </summary>
/// <param name="strSource">需要加密的明文</param>
/// <returns>返回16位加密結(jié)果,該結(jié)果取32位加密結(jié)果的第9位到25位</returns>
public string Get_MD5_Method1(string strSource)
{
//new
System.Security.Cryptography.MD5 md5 = new System.Security.Cryptography.MD5CryptoServiceProvider();
//獲取密文字節(jié)數(shù)組
byte[] bytResult = md5.ComputeHash(System.Text.Encoding.Default.GetBytes(strSource));
//轉(zhuǎn)換成字符串,并取9到25位
string strResult = BitConverter.ToString(bytResult, 4, 8);
//轉(zhuǎn)換成字符串,32位
//string strResult = BitConverter.ToString(bytResult);
//BitConverter轉(zhuǎn)換出來(lái)的字符串會(huì)在每個(gè)字符中間產(chǎn)生一個(gè)分隔符,需要去除掉
strResult = strResult.Replace("-", "");
return strResult;
}
/**//// <summary>
/// 方法二:通過(guò)調(diào)用特定加密算法的抽象類(lèi)上的 Create 方法,創(chuàng)建實(shí)現(xiàn)特定加密算法的對(duì)象。
/// </summary>
/// <param name="strSource">需要加密的明文</param>
/// <returns>返回32位加密結(jié)果</returns>
public string Get_MD5_Method2(string strSource)
{
string strResult = "";
//Create
System.Security.Cryptography.MD5 md5 = System.Security.Cryptography.MD5.Create();
//注意編碼UTF8、UTF7、Unicode等的選擇
byte[] bytResult = md5.ComputeHash(System.Text.Encoding.UTF8.GetBytes(strSource));
//字節(jié)類(lèi)型的數(shù)組轉(zhuǎn)換為字符串
for (int i = 0; i < bytResult.Length; i++)
{
//16進(jìn)制轉(zhuǎn)換
strResult = strResult + bytResult[i].ToString("X");
}
return strResult;
}
/**//// <summary>
/// 方法三:直接使用HashPasswordForStoringInConfigFile生成
/// </summary>
/// <param name="strSource">需要加密的明文</param>
/// <returns>返回32位加密結(jié)果</returns>
public string Get_MD5_Method3(string strSource)
{
return System.Web.Security.FormsAuthentication.HashPasswordForStoringInConfigFile(strSource, "MD5");
}
這些加密函數(shù)都是在服務(wù)器端執(zhí)行,也就是說(shuō),當(dāng)用戶(hù)輸入密碼后,從客戶(hù)端到服務(wù)器端傳輸時(shí),用戶(hù)的密碼沒(méi)有任何保護(hù),很危險(xiǎn)。銀行的做法是在客戶(hù)端安裝ActiveX控件,在客戶(hù)端就把一些重要信息進(jìn)行加密,再發(fā)送。這個(gè)偶就不會(huì)拉,很希望能學(xué)習(xí)學(xué)習(xí)做這種ActiveX控件。
加密哈希函數(shù)將任意長(zhǎng)度的二進(jìn)制字符串映射為固定長(zhǎng)度的小型二進(jìn)制字符串。加密哈希函數(shù)有這樣一個(gè)屬性:在計(jì)算上不大可能找到散列為相同的值的兩個(gè)不同的輸入;也就是說(shuō),兩組數(shù)據(jù)的哈希值僅在對(duì)應(yīng)的數(shù)據(jù)也匹配時(shí)才會(huì)匹配。數(shù)據(jù)的少量更改會(huì)在哈希值中產(chǎn)生不可預(yù)知的大量更改。所以你很難從加密后的文字中找到蛛絲馬跡。
SHA1的全稱(chēng)是Secure Hash Algorithm(安全哈希算法)
MD5 算法的哈希值大小為128位。而SHA1 算法的哈希值大小為160位。兩種算法都是不可逆。
雖說(shuō)2004年8月17日的美國(guó)加州圣巴巴拉的國(guó)際密碼學(xué)會(huì)議(Crypto'2004)上,來(lái)自中國(guó)山東大學(xué)的王小云教授做了破譯MD5、HAVAL-128、 MD4和RIPEMD算法的報(bào)告,公布了MD系列算法的破解結(jié)果。宣告了固若金湯的世界通行密碼標(biāo)準(zhǔn)MD5的堡壘轟然倒塌,引發(fā)了密碼學(xué)界的軒然大波。但是我覺(jué)得對(duì)于我們做普通的軟件來(lái)說(shuō),這個(gè)加密安全程度已經(jīng)足夠使用了。
我們平常用的最多的無(wú)非就是加密用戶(hù)密碼,把加密好的密碼存儲(chǔ)到數(shù)據(jù)庫(kù)中,進(jìn)行密碼比較的時(shí)候,把用戶(hù)輸入的密碼再進(jìn)行加密,然后與數(shù)據(jù)庫(kù)中的密文進(jìn)行比較。至于ASP.net類(lèi)中是如何實(shí)現(xiàn)加密算法的,這個(gè)我們不需要關(guān)心,會(huì)用就行了。
下面就是ASP.NET中幾種加密方法。加密算法有兩種,也就是上面提到的MD5和SHA1,這里我舉的例子是以MD5為例,SHA1大致相同,只是使用的類(lèi)不一樣。
MD5 相關(guān)類(lèi):
復(fù)制代碼 代碼如下:
System.Security.Cryptography.MD5
System.Security.Cryptography.MD5CryptoServiceProvider()
System.Web.Security.FormsAuthentication.HashPasswordForStoringInConfigFile(strSource, "MD5")
SHA1相關(guān)類(lèi):
復(fù)制代碼 代碼如下:
System.Security.Cryptography.SHA1
System.Security.Cryptography.SHA1CryptoServiceProvider()
System.Web.Security.FormsAuthentication.HashPasswordForStoringInConfigFile(strSource, "SHA1")
方法如下:(用的vs2005)
復(fù)制代碼 代碼如下:
/**//// <summary>
/// 方法一:通過(guò)使用 new 運(yùn)算符創(chuàng)建對(duì)象
/// </summary>
/// <param name="strSource">需要加密的明文</param>
/// <returns>返回16位加密結(jié)果,該結(jié)果取32位加密結(jié)果的第9位到25位</returns>
public string Get_MD5_Method1(string strSource)
{
//new
System.Security.Cryptography.MD5 md5 = new System.Security.Cryptography.MD5CryptoServiceProvider();
//獲取密文字節(jié)數(shù)組
byte[] bytResult = md5.ComputeHash(System.Text.Encoding.Default.GetBytes(strSource));
//轉(zhuǎn)換成字符串,并取9到25位
string strResult = BitConverter.ToString(bytResult, 4, 8);
//轉(zhuǎn)換成字符串,32位
//string strResult = BitConverter.ToString(bytResult);
//BitConverter轉(zhuǎn)換出來(lái)的字符串會(huì)在每個(gè)字符中間產(chǎn)生一個(gè)分隔符,需要去除掉
strResult = strResult.Replace("-", "");
return strResult;
}
/**//// <summary>
/// 方法二:通過(guò)調(diào)用特定加密算法的抽象類(lèi)上的 Create 方法,創(chuàng)建實(shí)現(xiàn)特定加密算法的對(duì)象。
/// </summary>
/// <param name="strSource">需要加密的明文</param>
/// <returns>返回32位加密結(jié)果</returns>
public string Get_MD5_Method2(string strSource)
{
string strResult = "";
//Create
System.Security.Cryptography.MD5 md5 = System.Security.Cryptography.MD5.Create();
//注意編碼UTF8、UTF7、Unicode等的選擇
byte[] bytResult = md5.ComputeHash(System.Text.Encoding.UTF8.GetBytes(strSource));
//字節(jié)類(lèi)型的數(shù)組轉(zhuǎn)換為字符串
for (int i = 0; i < bytResult.Length; i++)
{
//16進(jìn)制轉(zhuǎn)換
strResult = strResult + bytResult[i].ToString("X");
}
return strResult;
}
/**//// <summary>
/// 方法三:直接使用HashPasswordForStoringInConfigFile生成
/// </summary>
/// <param name="strSource">需要加密的明文</param>
/// <returns>返回32位加密結(jié)果</returns>
public string Get_MD5_Method3(string strSource)
{
return System.Web.Security.FormsAuthentication.HashPasswordForStoringInConfigFile(strSource, "MD5");
}
這些加密函數(shù)都是在服務(wù)器端執(zhí)行,也就是說(shuō),當(dāng)用戶(hù)輸入密碼后,從客戶(hù)端到服務(wù)器端傳輸時(shí),用戶(hù)的密碼沒(méi)有任何保護(hù),很危險(xiǎn)。銀行的做法是在客戶(hù)端安裝ActiveX控件,在客戶(hù)端就把一些重要信息進(jìn)行加密,再發(fā)送。這個(gè)偶就不會(huì)拉,很希望能學(xué)習(xí)學(xué)習(xí)做這種ActiveX控件。
您可能感興趣的文章:
- ASP.NET中DES加密與解密MD5加密幫助類(lèi)的實(shí)現(xiàn)代碼
- VB.NET實(shí)現(xiàn)的MD5加密算法示例【32位】
- .NET MD5加密解密代碼解析
- asp.net實(shí)現(xiàn)的MD5加密和DES加解密算法類(lèi)完整示例
- asp.net實(shí)現(xiàn)md5加密
- vb 中的MD5加密在asp.net中的實(shí)現(xiàn)
- asp.net中使用cookie與md5加密實(shí)現(xiàn)記住密碼功能的實(shí)現(xiàn)代碼
- 徹底解決ASP.NET MD5加密中文結(jié)果和ASP不一致的問(wèn)題
- asp.net下常用的加密算法MD5、SHA-1應(yīng)用代碼
- asp.net中MD5 16位和32位加密函數(shù)
- ASP.net中md5加密碼的方法
- .net core使用MD5加密解密字符串
相關(guān)文章
ASP.NET堆和棧一之基本概念和值類(lèi)型內(nèi)存分配
這篇文章介紹了ASP.NET堆和棧的基本概念和值類(lèi)型內(nèi)存分配,文中通過(guò)示例代碼介紹的非常詳細(xì)。對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2022-08-08web用戶(hù)控件調(diào)用.aspx頁(yè)面里的方法
今天在一QQ技術(shù)群有朋友問(wèn): 他在web用戶(hù)控件中(.ascx)中放了一個(gè)dropdownlist控件,一個(gè)textbox控件和一個(gè)button控件。2009-04-04asp.net Gridview分頁(yè)保存選項(xiàng)
這篇文章介紹了asp.net Gridview分頁(yè)保存選項(xiàng),有需要的朋友可以參考一下2013-08-08實(shí)例說(shuō)明asp.net中的簡(jiǎn)單角色權(quán)限控制
權(quán)限控制在信息管理中屬于基本功能,權(quán)限控制中其中以Window權(quán)限為模型的角色用戶(hù)(也稱(chēng)用戶(hù)組用戶(hù))模型使用較多。本文以網(wǎng)站管理后臺(tái)權(quán)限控制為例簡(jiǎn)要說(shuō)明。2009-10-10詳解ASP.NET Core 2.0 路由引擎之網(wǎng)址生成(譯)
這篇文章主要介紹了詳解ASP.NET Core 2.0 路由引擎之網(wǎng)址生成(譯),小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2017-11-11asp.net?core?中的Jwt(Json?Web?Token)的使用詳解
session不支持分布式并且在服務(wù)器存儲(chǔ)一份用戶(hù)登錄的信息,這份登錄信息會(huì)在響應(yīng)時(shí)傳遞給瀏覽器,告訴其保存為cookie,以便下次請(qǐng)求時(shí)發(fā)送給我們的應(yīng)用,這篇文章主要介紹了asp.net?core?中的Jwt(Json?Web?Token)的使用,需要的朋友可以參考下2022-10-10在ASP.Net Core中使用Lamar的全過(guò)程
這篇文章主要給大家介紹了關(guān)于在ASP.Net Core中使用Lamar的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2021-03-03