自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

ASP.NET MD5和SHA1加密方法的淺析

開發(fā) 后端
ASP.NET MD5和SHA1加密方法是如何實(shí)現(xiàn)的呢?常用的類有哪些呢?那么本文就向你介紹ASP.NET MD5和SHA1加密方法的這些情況。

ASP.NET MD5和SHA1加密方法有哪些呢?首先我們來看看什么是MD5?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ù)字簽名軟件簽署私人密匙前被"壓縮"成一種保密的格式(就是把一個(gè)任意長度的字節(jié)串變換成一定長的大整數(shù))。不管是md2、md4還是md5,它們都需要獲得一個(gè)隨機(jī)長度的信息并產(chǎn)生一個(gè)128位的信息摘要。

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

ASP.NET SHA1加密中的SHA1是什么呢?SHA1的全稱是Secure Hash Algorithm(安全哈希算法)

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

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

ASP.NET MD5和SHA1加密方法的概念介紹過了,現(xiàn)在來看看具體的類有哪些呢?

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

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

ASP.NET MD5和SHA1加密之MD5 相關(guān)類:

System.Security.Cryptography.MD5

System.Security.Cryptography.MD5CryptoServiceProvider()

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

ASP.NET MD5和SHA1加密之SHA1相關(guān)類:

System.Security.Cryptography.SHA1

System.Security.Cryptography.SHA1CryptoServiceProvider()

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

方法如下:(用的vs2005)

  1. /**//// <summary>  
  2.  /// 方法一:通過使用 new 運(yùn)算符創(chuàng)建對象  
  3.  /// </summary>  
  4.  /// <param name="strSource">需要加密的明文</param>  
  5.  /// <returns>返回16位加密結(jié)果,該結(jié)果取32位加密結(jié)果的第9位到25位</returns>  
  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)換出來的字符串會在每個(gè)字符中間產(chǎn)生一個(gè)分隔符,需要去除掉  
  20.   strResult = strResult.Replace("-""");  
  21.   return strResult;  
  22.  }  
  23.  
  24.  /**//// <summary>  
  25.  /// 方法二:通過調(diào)用特定加密算法的抽象類上的 Create 方法,創(chuàng)建實(shí)現(xiàn)特定加密算法的對象。  
  26.  /// </summary>  
  27.  /// <param name="strSource">需要加密的明文</param>  
  28.  /// <returns>返回32位加密結(jié)果</returns>  
  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.   //字節(jié)類型的數(shù)組轉(zhuǎn)換為字符串  
  40.   for (int i = 0; i < bytResult.Length; i++)  
  41.   {  
  42.    //16進(jìn)制轉(zhuǎn)換   
  43.    strResult = strResult + bytResult[i].ToString("X");  
  44.   }  
  45.   return strResult;  
  46.   }  
  47.    
  48.   /**//// <summary>  
  49.   /// 方法三:直接使用HashPasswordForStoringInConfigFile生成  
  50.   /// </summary>  
  51.   /// <param name="strSource">需要加密的明文</param>  
  52.  /// <returns>返回32位加密結(jié)果</returns>  
  53.   public string Get_MD5_Method3(string strSource)  
  54.   {  
  55.   return System.Web.Security.FormsAuthentication.HashPasswordForStoringInConfigFile(strSource, "MD5");  
  56.   } 

這些加密函數(shù)都是在服務(wù)器端執(zhí)行,也就是說,當(dāng)用戶輸入密碼后,從客戶端到服務(wù)器端傳輸時(shí),用戶的密碼沒有任何保護(hù),很危險(xiǎn)。銀行的做法是在客戶端安裝ActiveX控件,在客戶端就把一些重要信息進(jìn)行加密,再發(fā)送。這個(gè)偶就不會拉,很希望能學(xué)習(xí)學(xué)習(xí)做這種ActiveX控件。

ASP.NET MD5和SHA1加密的基本情況就介紹到這里,希望你對ASP.NET MD5和SHA1加密有所了解。

【編輯推薦】

  1. IIS ASP.NET的進(jìn)程模式淺析
  2. ASP.NET程序小數(shù)點(diǎn)保留兩位解析
  3. ASP.NET上傳文件控件實(shí)例詳解
  4. ASP.NET學(xué)習(xí)的九大步驟詳解
  5. ASP.NET與ASP相比的優(yōu)點(diǎn)淺析
責(zé)任編輯:仲衡 來源: CSDN博客
相關(guān)推薦

2009-09-09 18:35:07

C# 加密MD5和SHA1

2009-07-28 16:39:16

VB.NET的MD5加

2009-07-22 18:03:00

ASP.NET ASP

2017-01-04 15:30:33

Android Stu開發(fā)工具自動(dòng)簽名

2016-12-15 09:26:53

MD5加密

2009-08-04 17:28:45

Apache支持ASP

2010-06-25 16:19:17

2009-07-27 10:18:12

TypeResolveASP.NET

2009-07-31 12:43:59

ASP.NET MVC

2009-08-05 15:50:13

ASP.NET優(yōu)點(diǎn)

2009-07-27 09:29:38

ASP.NET中Jav

2009-07-20 16:09:39

2009-07-27 15:34:11

MembershipASP.NET

2009-07-24 13:41:15

ASP.NET AJA

2009-08-05 18:36:12

ASP.NET Che

2009-07-24 10:53:51

ASP.NET實(shí)現(xiàn)靜態(tài)

2009-08-10 13:32:15

ASP.NET TimASP.NET組件設(shè)計(jì)

2009-06-06 18:57:47

MD5加密類Java Bean

2022-10-18 22:21:51

2020-10-15 08:20:52

MD5算法加密的過程
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號