主頁 > 知識庫 > asp.net實(shí)現(xiàn)md5加密

asp.net實(shí)現(xiàn)md5加密

熱門標(biāo)簽:征途美甲店地圖標(biāo)注 電銷語音機(jī)器人型號參數(shù) 百度地圖怎樣做地圖標(biāo)注 400電話如何申請取消 昆明語音電銷機(jī)器人價(jià)格 柳州電銷機(jī)器人公司 騰訊地圖標(biāo)注手機(jī) 浦發(fā)電話機(jī)器人提醒還款 太原400電話上門辦理

MD5加密簡單的說就是把一段明文 通過某種運(yùn)算方式 求出密文。例如:明文為:abcdefg 通過一些列運(yùn)算 得到 密文 7ac66c0f148de9519b8bd264312c4d64

它具有兩個(gè)特性:1.無碰撞,2.不可逆。

無碰撞是指: 7ac66c0f148de9519b8bd264312c4d64 這段密文 只能由 abcdefg 這段明文得到,除此之外其他的 明文加密后 其值 絕對不會(huì)等于 7ac66c0f148de9519b8bd264312c4d64,也就是說 沒有那兩個(gè)明文 加密后 會(huì)得到相同的密文。

不可逆是指: 明文通過加密后得到密文,而無法通過密文 求出明文。也就是說 當(dāng)我們知道明文 adcdefg 可以通過加密得到 7ac66c0f148de9519b8bd264312c4d64,但是我們?nèi)绻?某段文字 加密后 得到7ac66c0f148de9519b8bd264312c4d64,卻無法算出 7ac66c0f148de9519b8bd264312c4d64這段文字是由誰加密而來的。

那么有同學(xué)一定會(huì)問,具體應(yīng)該運(yùn)用在什么地方?

一般來說 我們在做網(wǎng)站登錄系統(tǒng)的時(shí)候 密碼都是密文保存的,一般用的都是MD5加密。

用戶在填寫用戶名 密碼 點(diǎn)擊注冊之后,我們驗(yàn)證通過,要把用戶信息存入數(shù)據(jù)庫的時(shí)候,就需要先把用戶輸入的密碼,通過MD5加密的方式,把加密后的密文,存入密碼的字段。

那么一定有同學(xué)會(huì)細(xì)心的發(fā)現(xiàn),剛剛還提到過 MD5加密是不可逆的,那么用戶登錄的時(shí)候如何判斷用戶輸入的密碼是否正確的呢?

例如 用戶設(shè)置的密碼 為 abcdefg,而存儲的時(shí)候 我們存儲的是 abcdefg加密過之后得到的值 7ac66c0f148de9519b8bd264312c4d64,那么用戶再次登錄時(shí) 會(huì)輸入密碼abcdefg,我們?nèi)绾伪容^兩者是否相等?

我們無法通過 加密后的值換算出 加密前的值,因此 我們通常的做法是,把用戶再次登錄時(shí) 輸入的密碼 再次加密 和數(shù)據(jù)庫中 存放的值進(jìn)行比對,如果相等 則說明輸入的密碼正確。

OK,基本原理和運(yùn)用場景基本說的差不多了,最后再來說說 在ASP.NET中如何進(jìn)行MD5加密。

在ASP.NET中MD5的加密方式很簡單,代碼如下:

復(fù)制代碼 代碼如下:

FormsAuthentication.HashPasswordForStoringInConfigFile(str, "MD5").ToLower();

需要注意的是,如果MD5加密的時(shí)候轉(zhuǎn)換的是小寫,那么在驗(yàn)證的時(shí)候也要轉(zhuǎn)換成小寫,保持統(tǒng)一。另外上述方式為32位的MD5加密方式,如果是16位的 則取32位加密結(jié)果的中間16位的值即可。

這里還有示例,大家參考一下

復(fù)制代碼 代碼如下:

/// summary>
 /// MD5加密
 /// /summary>
 /// param name="strSource">需要加密的明文/param>
 /// returns>返回32位加密結(jié)果/returns>
 public static string Get_MD5(string strSource, string sEncode)
 {
     //new
     System.Security.Cryptography.MD5 md5 = new System.Security.Cryptography.MD5CryptoServiceProvider();

     //獲取密文字節(jié)數(shù)組
     byte[] bytResult = md5.ComputeHash(System.Text.Encoding.GetEncoding(sEncode).GetBytes(strSource));

     //轉(zhuǎn)換成字符串,并取9到25位
     //string strResult = BitConverter.ToString(bytResult, 4, 8); 
     //轉(zhuǎn)換成字符串,32位

     string strResult = BitConverter.ToString(bytResult);

     //BitConverter轉(zhuǎn)換出來的字符串會(huì)在每個(gè)字符中間產(chǎn)生一個(gè)分隔符,需要去除掉
     strResult = strResult.Replace("-", "");

     return strResult.ToLower();
 }

您可能感興趣的文章:
  • ASP.NET中DES加密與解密MD5加密幫助類的實(shí)現(xiàn)代碼
  • VB.NET實(shí)現(xiàn)的MD5加密算法示例【32位】
  • .NET MD5加密解密代碼解析
  • asp.net實(shí)現(xiàn)的MD5加密和DES加解密算法類完整示例
  • vb 中的MD5加密在asp.net中的實(shí)現(xiàn)
  • asp.net中使用cookie與md5加密實(shí)現(xiàn)記住密碼功能的實(shí)現(xiàn)代碼
  • ASP.NET中MD5與SHA1加密的幾種方法
  • 徹底解決ASP.NET MD5加密中文結(jié)果和ASP不一致的問題
  • asp.net下常用的加密算法MD5、SHA-1應(yīng)用代碼
  • asp.net中MD5 16位和32位加密函數(shù)
  • ASP.net中md5加密碼的方法
  • .net core使用MD5加密解密字符串

標(biāo)簽:德陽 江蘇 天門 陽泉 白山 蘭州 新疆 張家界

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《asp.net實(shí)現(xiàn)md5加密》,本文關(guān)鍵詞  asp.net,實(shí)現(xiàn),md5,加密,asp.net,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《asp.net實(shí)現(xiàn)md5加密》相關(guān)的同類信息!
  • 本頁收集關(guān)于asp.net實(shí)現(xiàn)md5加密的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章