c#相容PHP中的md5

傑克.陳發表於2014-12-08
原文: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;
   } 

} 

 

 

 


相關文章