如何使php的MD5与C#的MD5一致?

Posted mimime

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了如何使php的MD5与C#的MD5一致?相关的知识,希望对你有一定的参考价值。

有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一致?的主要内容,如果未能解决你的问题,请参考以下文章

C#代码加密字符串,与SQL加密结果不一致

PHP中的md5与Java中的md5加密结果不一致问题

说能说清楚C#md5和php md5加密技术的区别,以实例说明

C#基础-MD5验证

制作哈希的 md5 哈希

PHP特性总结与例题