C#與PHP的md5計算後果不同的處理辦法。本站提示廣大學習愛好者:(C#與PHP的md5計算後果不同的處理辦法)文章只能為提供參考,不一定能成為您想要的結果。以下是C#與PHP的md5計算後果不同的處理辦法正文
問題重現
這個 API 是事先給 Lyra 使用做激活用的,遂翻開 Lyra 試了下,卻發現一切正常,於是可以掃除服務端的問題
放出招致錯誤的源碼(來自 MSDN):
public string CalculateMD5Hash(string input)
{
// step 1, calculate MD5 hash from input
MD5 md5 = System.Security.Cryptography.MD5.Create();
byte[] inputBytes = System.Text.Encoding.ASCII.GetBytes(input);
byte[] hash = md5.ComputeHash(inputBytes);
// step 2, convert byte array to hex string
StringBuilder sb = new StringBuilder();
for (int i = 0; i < hash.Length; i++)
{ sb.Append(hash[i].ToString(“X2”));
}
return sb.ToString();
}
本質
MD5 有很多版本,其實這段代碼並沒有錯,但是 php 的 md5 函數默許前往的是 32位小寫 ,而以上這一段前往的是 16位小寫
於是想方法把這個 func 改為 32位小寫輸入即可
public static String md5(String s)
{
MD5 md5 = new MD5CryptoServiceProvider();
byte[] bytes = System.Text.Encoding.UTF8.GetBytes(s);
bytes = md5.ComputeHash(bytes);
md5.Clear();
string ret = "";
for (int i = 0; i < bytes.Length; i++)
{
ret += Convert.ToString(bytes[i], 16).PadLeft(2, '0');
}
return ret.PadLeft(32, '0');
}
總結
以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或許任務能帶來一定的協助,假如有疑問大家可以留言交流。