程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> .NET網頁編程 >> 關於.NET >> .NET中的MD5及hash加密以及密文輸出(C#)

.NET中的MD5及hash加密以及密文輸出(C#)

編輯:關於.NET

在網上搜羅了一下,搜到很多雷同文章,摘引如下:

public static string MD5(string Sourcein)

   {

    MD5CryptoServiceProvider MD5CSP = new MD5CryptoServiceProvider();

    byte[] MD5Source = System.Text.Encoding.UTF8.GetBytes(Sourcein);

    byte[] MD5Out = MD5CSP.ComputeHash(MD5Source);

    return Convert.ToBase64String(MD5Out);

   }

而如此做的話,Convert.ToBase64String出來的會是一串包含字母數字以及符合的字符串,例如:afw1fw3j=-

這樣是與儲存在數據庫中的加密後字符串不相同的,自然無法比較。數據庫中儲存的是類似BABA327D241746EE0829E7E88117D4D5這樣的字符串。

Google許久,未曾找到在ASP.NET中是怎麼實現上述樣子的輸出的。於是自己動手,查閱MSDN,無數次實踐,終於找到方法,就是用.NET中的BitConverter類,廢話不多說,把代碼貼出來,

private void btnMd5_Click( object sender, EventArgs e ) {
       if (string.IsNullOrEmpty(txtSrc.Text)) {
         txtSrc.Text = "Please Input your string to Encrype";
         return;
       }
       MD5CryptoServiceProvider md5Encrypter = new MD5CryptoServiceProvider();
       byte[] theSrc = Encoding.UTF8.GetBytes( txtSrc.Text );
       byte[] theResBytes = md5Encrypter.ComputeHash( theSrc );
       txtResult.Text = BitConverter.ToString( theResBytes ).Replace( "-", "" );
     }
     private void btnHash_Click( object sender, EventArgs e ) {
       if (string.IsNullOrEmpty( txtSrc.Text )) {
         txtSrc.Text = "Please Input your string to Encrype";
         return;
       }
       HashAlgorithm hashEncrypter = new SHA1Managed();
       byte[] theSrc = Encoding.UTF8.GetBytes( txtSrc.Text );
       byte[] theResBytes = hashEncrypter.ComputeHash( theSrc );
       txtResult.Text = BitConverter.ToString( theResBytes ).Replace( "-", "" );
     }

BitConverter.ToString出來的是類似BA-BA-32-7D-24-17-46-EE這樣結果,鼠標放到BitConverter.ToString上發現它的summary:Converts the numeric value of each element of a specified array of bytes to its equivalent hexadecimal string representation.

把string中的‘-’分離出來的方法應該是有很多種,鄙人試驗過之後感覺上述方法比較簡單,至於執行效率沒有比較O(∩_∩)O

需要此工具的可以下載收藏之:

MD5及hash加密工具 (右鍵另存為)

由此可見,漢字也是可以加密的,沒有亂碼。

耐心看到最後的有福啦,其實在System.Web.Security.FormsAuthentication 中有一個專門用於加密密碼的方法,它就是HashPasswordForStoringInConfigFile   此法需要兩個參數,自己MSDN吧,遺憾的是此法只實現了MD5和SHA1兩種加密方法。

在此推薦一個在線加密工具,此站有很多比較實用的工具。http://www.aspnetresources.com/tools/pwdhash.aspx

如有問題,請看家不吝賜教~

附,剛剛看了一下 HashPasswordForStoringInConfigFile的內部實現,把代碼貼上來了~

代碼

public static string HashPasswordForStoringInConfigFile(string password, string passwordFormat)
{
     HashAlgorithm algorithm;
     if (password == null)
     {
         throw new ArgumentNullException("password");
     }
     if (passwordFormat == null)
     {
         throw new ArgumentNullException("passwordFormat");
     }
     if (StringUtil.EqualsIgnoreCase(passwordFormat, "sha1"))
     {
         algorithm = SHA1.Create();
     }
     else
     {
         if (!StringUtil.EqualsIgnoreCase(passwordFormat, "md5"))
         {
             throw new ArgumentException(SR.GetString("InvalidArgumentValue", new object[] { "passwordFormat" }));
         }
         algorithm = MD5.Create();
     }
     return MachineKeySection.ByteArrayToHexString(algorithm.ComputeHash(Encoding.UTF8.GetBytes(password)), 0);
}

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved