-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
感谢您的帮助。
你是100%确定所有的值都是**完全相同吗?你是否正在运行,逐行检查代码以确定它?如果只有一位不同,你会得到不同的散列。 –
请编辑或删除这个问题,因为它目前的值非常低。看起来很清楚,'Encoding.Default.GetBytes(key + secretKey)'和'$ prec。$ SecretKey'不是同一个字节序列,但不清楚为什么这对任何人都有用。 –
@KennyEvitt这两个代码给出了我们测试的相同结果。你测试过了吗? – safa