標籤:nbsp string md5加密 graph ret 位元組 body span audio
項目開發過程中需要用到MD5加密,最開始的使用使用加密方法:
public static string GetMD5(string str){ byte[] b = System.Text.Encoding.Default.GetBytes(str); b = new System.Security.Cryptography.MD5CryptoServiceProvider().ComputeHash(b); string ret = ""; for (int i = 0; i < b.Length; i++) { ret += b[i].ToString("x").PadLeft(2, ‘0‘); } return ret;}
在一開始的測試過程中沒有出現問題,後來傳入的參數包含中文後,就出現問題了,經過排查返現Encoding.Default使用的是預設的編碼:gb2312
所以改變加密方式:
public static string UserMd5(string str) { string cl = str; string pwd = ""; MD5 md5 = MD5.Create();//執行個體化一個md5對像
// 加密後是一個位元組類型的數組,這裡要注意編碼UTF8/Unicode等的選擇 byte[] s = md5.ComputeHash(Encoding.UTF8.GetBytes(cl)); // 通過使用迴圈,將位元組類型的數群組轉換為字串,此字串是常規字元格式設定化所得 for (int i = 0; i < s.Length; i++) { // 將得到的字串使用十六進位類型格式。格式後的字元是小寫字母,如果使用大寫(X)則格式後的字元是大寫字元 pwd = pwd + s[i].ToString("x"); } return pwd; }
但是在和對方測試過程中,發現我這邊的MD5加密編碼,經常出現少一位或幾位的問題;後來分析發現是 字串格式符的問題, X 表示大寫, x 表示小寫, X2和x2表示不省略首位為0的十六進位數字;
比如:ox0A, 使用X== 0xA, 使用X2==0x0A
則改變方法最後的輸出格式:
public static string UserMd5(string str) { string cl = str; string pwd = ""; MD5 md5 = MD5.Create();//執行個體化一個md5對像 // 加密後是一個位元組類型的數組,這裡要注意編碼UTF8/Unicode等的選擇 byte[] s = md5.ComputeHash(Encoding.UTF8.GetBytes(cl)); // 通過使用迴圈,將位元組類型的數群組轉換為字串,此字串是常規字元格式設定化所得 for (int i = 0; i < s.Length; i++) { // 將得到的字串使用十六進位類型格式。格式後的字元是小寫字母,如果使用大寫(X)則格式後的字元是大寫字元 pwd = pwd + s[i].ToString("x2"); } return pwd; }
C# MD5 32位加密 UTF-8編碼