標籤:.text builder 使用 handle 指南 ++ url public ide
有c#產生MD5的代碼如下:
class CreateMD5 { static void Main(string[] args) { string source = "提問指南"; using (MD5 md5Hash = MD5.Create()) { string hash = GetMd5Hash(md5Hash, source); Console.WriteLine( hash); } } static string GetMd5Hash(MD5 md5Hash, string input) { //這裡是 Unicode byte[] data = md5Hash.ComputeHash(Encoding.Unicode.GetBytes(input)); StringBuilder sBuilder = new StringBuilder(); for (int i = 0; i < data.Length; i++) { sBuilder.Append(data[i].ToString("x2")); } return sBuilder.ToString(); } }
上述代碼產生的MD5是 f5da53705563c657581a6d0853286fdc 現在問題是,c#產生的MD5 與 PHP 產生的MD5 不一致
由於業務限制,不能更改c#代碼,只能從PHP下手。
回答:
md5前操作一步
$tmp = mb_convert_encoding(‘提問指南‘, ‘utf-16le‘, ‘utf8‘);
原文:c#相容 PHP中的md5
由於工作需要,需要使用C#去對一個php程式做二次開發.在登入驗證的時候,發現一個小問題.
就是用C#寫的md5演算法得出的結果和php的md5()得出的結果有時候會不一樣. 導致有些帳號的密碼驗證不能通過.後來網上找了一下,在國外一個網站上找到了答案.
C#常用的MD5演算法.
public static string MD5(string password) { byte[] textBytes = System.Text.Encoding.Default.GetBytes(password); try { System.Security.Cryptography.MD5CryptoServiceProvider cryptHandler; cryptHandler = new System.Security.Cryptography.MD5CryptoServiceProvider(); byte[] hash = cryptHandler.ComputeHash (textBytes); string ret = ""; foreach (byte a in hash) { ret += a.ToString ("x"); } return ret ; } catch { throw; }
}
但是此演算法與md5()得出的結果是不一樣的.後調整為如下,即可以了.
public static string MD5(string password) { byte[] textBytes = System.Text.Encoding.Default.GetBytes(password); try { System.Security.Cryptography.MD5CryptoServiceProvider cryptHandler; cryptHandler = new System.Security.Cryptography.MD5CryptoServiceProvider(); byte[] hash = cryptHandler.ComputeHash (textBytes); string ret = ""; foreach (byte a in hash) { if (a<16) ret += "0" + a.ToString ("x"); else ret += a.ToString ("x"); } return ret ; } catch { throw; }
}
【轉】如何使php的MD5與C#的MD5一致?