2016-08-02 70 views
-1

我想用c#md5和php md5来计算相同的结果,但他们给出了不同的结果。 c#代码必须与php代码相同。c#md5和php md5不是马赫

public string ToMD5(string orderId, string statusCode, string secretKey) 
{ 
    string key = orderId + "+" + statusCode; 
    key = Base64Encode(key); 
    MD5 m = System.Security.Cryptography.MD5.Create(); 
    byte[] h = m.ComputeHash(Encoding.Default.GetBytes(key + secretKey)); 
    string r = ""; 

    foreach (byte b in h) 
    { 
     r += b.ToString("X2"); 
    } 

    return r; 
} 

这里是PHP代码:

$key = $orderid."+".$status; 
$prec = base64_encode($key); 
$prec = $prec.$SecretKey; 
$prec = md5($prec); 
echo $prec; 

C#的回报:CEC71705E5A25CCD21609B72053539FC

PHP回报:f1542715b25b302553119fda1e8567bb

感谢您的帮助。

+1

你是100%确定所有的值都是**完全相同吗?你是否正在运行,逐行检查代码以确定它?如果只有一位不同,你会得到不同的散列。 –

+0

请编辑或删除这个问题,因为它目前的值非常低。看起来很清楚,'Encoding.Default.GetBytes(key + secretKey)'和'$ prec。$ SecretKey'不是同一个字节序列,但不清楚为什么这对任何人都有用。 –

+0

@KennyEvitt这两个代码给出了我们测试的相同结果。你测试过了吗? – safa

回答

2

这些2行产生相同的MD5哈希值:

echo md5("12345+200OKSecret"); 

new List<byte>(MD5.Create().ComputeHash(Encoding.Default.GetBytes("12345+200OKSecret"))).ForEach(x => Console.Write("{0:X2}",x)); 

结果:

8df9a16122b34e41d49ad11d9f1e0c73 

8DF9A16122B34E41D49AD11D9F1E0C73 

检查您正在哈希的字符串的值 - 它们必须不同。

+0

感谢您的信息。你是对的 。这是我的错误.. – safa