標籤:
(1)
using System.Security.Cryptography;
byte[] result = Encoding.Default.GetBytes(yps); //tbPass為輸入密碼的文字框 MD5 md5 = new MD5CryptoServiceProvider(); byte[] output = md5.ComputeHash(result); string str = BitConverter.ToString(output).Replace("-", ""); if(str.Length!=32) System.Diagnostics.Debug.WriteLine("開始調試"); return str;
(2)
using System.Security.Cryptography;
string cl = yps; string pwd = ""; MD5 md5 = MD5.Create();//執行個體化一個md5對像 // 加密後是一個位元組類型的數組,這裡要注意編碼UTF8/Unicode等的選擇 byte[] s = md5.ComputeHash(Encoding.UTF8.GetBytes(cl)); if (s.Length != 16) System.Diagnostics.Debug.WriteLine("開始調試"); // 通過使用迴圈,將位元組類型的數群組轉換為字串,此字串是常規字元格式設定化所得 for (int i = 0; i < s.Length; i++) { // 將得到的字串使用十六進位類型格式。格式後的字元是小寫字母,如果使用大寫(X)則格式後的字元是大寫字元 pwd = pwd + s[i].ToString("X"); } if (pwd.Length != 32) System.Diagnostics.Debug.WriteLine("開始調試"); return pwd;
(3)
using System.Web.Security;
password = FormsAuthentication.HashPasswordForStoringInConfigFile(cpassword, "MD5");
上述三種方式的MD5加密,具體原理不知了。說說微小區別
(1)與(3)的Md5值是一樣的。(2)與(1)、(3)的Md5值有微小區別,原因是
pwd = pwd + s[i].ToString("X"); 該語句轉化為16進位時,如果轉化值為一位,比如3等,另外兩種方法此時轉化後的值為03,造成
最後的Md5值小於等於32位,從而造成(2)與(1)、(3)的Md5值不一定相等
所以,如果Md5加密,最好使用同一種方式。
關於網上常見的幾種MD5加密的區別