標籤:
原文:如何在C#中產生與PHP一樣的MD5 Hash Code
最近在對一個現有的系統進行C#改造,該系統以前是用PHP做的,背景管理員登陸用的是MD5密碼編譯演算法。在PHP中,要對一個字串進行MD5加密非常簡單,一行代碼即可:
md5("Something you want to encrypt.")
直接調用md5()方法,然後將要進行MD5加密的字串傳進去,就可以得到返回的hash code。在C#中應該也會有對應的演算法吧!對嗎?我首先嘗試了下面的代碼,結果得到的hash code和PHP不一樣。
public static string MD5(string stringToHash){ return FormsAuthentication.HashPasswordForStoringInConfigFile(stringToHash, "md5");}
所以,我們不得不借用C#的MD5CryptoServiceProvider對象自己寫代碼進行轉換。
1. 執行個體化MD5CryptoServiceProvider對象
2. 將字串轉換成byte數組
3. 使用MD5CryptoServiceProvider對象的ComputeHash()方法將byte數組進行加密,返迴轉換後的byte數組
4. 在講byte數群組轉換成字串之前,還需要對其進行遍曆並做如下轉換:
myByte.ToString("x2").ToLower()
然後,你才能得到和PHP中一樣的MD5 hash code。為什麼在.NET中要這麼麻煩,或許這也是為什麼那麼多的開發人員仍然熱衷於PHP開發的理由之一,每一門程式設計語言都有它自身的魅力,也都有它存在的意義!
基於上面的討論,完整的代碼如下:
public static string MD5ForPHP(string stringToHash){ var md5 = new System.Security.Cryptography.MD5CryptoServiceProvider(); byte[] emailBytes = Encoding.UTF8.GetBytes(stringToHash.ToLower()); byte[] hashedEmailBytes = md5.ComputeHash(emailBytes); StringBuilder sb = new StringBuilder(); foreach (var b in hashedEmailBytes) { sb.Append(b.ToString("x2").ToLower()); } return sb.ToString();}
或者,你也可以把上面的方法寫成一個C#擴充方法,只需要修改方法簽名即可。
public static string MD5ForPHP(this String, string stringToHash){ // Your code here.}
PHP程式和C#程式在許多方面都會涉及到格式之間的轉換,如果運行PHP的伺服器是UNIX類型的,則還會存在日期格式之間的轉換。下面的兩個方法展示了如何將UNIX時間轉換成C# DateTime以及如何將C# DateTime轉換成UNIX時間。
public static DateTime UnixTimeStampToDateTime(long unixTimeStamp){ // Unix timestamp is seconds past epoch DateTime dtDateTime = new DateTime(1970, 1, 1, 0, 0, 0, 0, System.DateTimeKind.Utc);
return dtDateTime.AddSeconds(unixTimeStamp);}public static long DateTimeToUnixTimeStamp(DateTime datetime){ TimeSpan span = (datetime - new DateTime(1970, 1, 1, 0, 0, 0, 0, DateTimeKind.Utc)); return (long)span.TotalSeconds;}
如何在C#中產生與PHP一樣的MD5 Hash Code