1. 程式人生 > >C# MD5 32位加密 UTF-8編碼

C# MD5 32位加密 UTF-8編碼

spl 十六進制 post ring one 類型 開始 出現問題 int

項目開發過程中需要用到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編碼