當要進行MD5加密的字符串不含中文時,那麼ASP.NET的加密結果和ASP是一致的:
Response.Write(FormsAuthentication.HashPasswordForStoringInConfigFile ("www.mzwu.com", "MD5"));
//結果:D66E1F138689B9B5AA4C520D9EAFFB61
Response.Write(MD5("www.mzwu.com",32))
'結果:d66e1f138689b9b5aa4c520d9eaffb61
當要進行MD5加密的字符串含中文時,兩者的加密結果就不一致了:
Response.Write(FormsAuthentication.HashPasswordForStoringInConfigFile("木子屋", "MD5"));
//結果:34D9CBD5164C47058DFA3AF832E2D1DC
Response.Write(MD5("木子屋",32))
'結果:0a40a90190da023ae7aa17771663a41e
我們知道,ASP.NET默認使用utf-8編碼格式,而ASP使用的是gb2312編碼格式,正是由於這編碼格式不 同,才導致了兩者對中文加密結果的不同。下邊我們看看怎麼讓ASP.NET的編碼結果和ASP一樣,那也就意 味著要讓ASP.NET采用gb2312編碼格式,這點 FormsAuthentication.HashPasswordForStoringInConfigFile()方法是辦不到的,我們得使用 System.Security.Cryptography.MD5CryptoServiceProvider對象的ComputeHash方法來進行加密:
MD5CryptoServiceProvider MD5 = new MD5CryptoServiceProvider();
Response.Write(BitConverter.ToString(MD5.ComputeHash(Encoding.GetEncoding ("gb2312").GetBytes("木子屋"))).Replace("-", ""));
//結果:0A40A90190DA023AE7AA17771663A41E
若要再使用utf-8加密也非常容易:
MD5CryptoServiceProvider MD5 = new MD5CryptoServiceProvider();
Response.Write(BitConverter.ToString(MD5.ComputeHash(Encoding.GetEncoding("utf- 8").GetBytes("木子屋"))).Replace("-", ""));
//結果:34D9CBD5164C47058DFA3AF832E2D1DC
問題似乎是比較完美的解決了,我們再來完善一下:當要加密的字符串是從其他頁面傳進來時,其他 頁面采用的編碼格式可能是gb2312,可能是utf-8,還可能是其他的編碼格式,怎麼解決呢?你可能會覺 得很簡單啊,使用它先前的編碼格式進行加密不就行了?實際測試中你會發現兩個很嚴重的問題:
1. 我們無從知道參數傳過來時是使用什麼編碼格式;
2. 如果兩個頁面使用的編碼方式不一樣,那麼Request接收到的參數值會亂碼,那就不要談加密了;