当前位置: 移动技术网 > IT编程>开发语言>c# > C#与PHP的md5计算结果不同的解决方法

C#与PHP的md5计算结果不同的解决方法

2019年07月18日  | 移动技术网IT编程  | 我要评论

问题重现

这个 api 是当时给 lyra 应用做激活用的,遂打开 lyra 试了下,却发现一切正常,于是可以排除服务端的问题

放出导致错误的源码(来自 msdn):

public string calculatemd5hash(string input)
{
  // step 1, calculate md5 hash from input
  md5 md5 = system.security.cryptography.md5.create();
  byte[] inputbytes = system.text.encoding.ascii.getbytes(input);
  byte[] hash = md5.computehash(inputbytes);
  // step 2, convert byte array to hex string
  stringbuilder sb = new stringbuilder();
  for (int i = 0; i < hash.length; i++)
  { sb.append(hash[i].tostring(“x2”));
  }
  return sb.tostring();
}

实质

md5 有很多版本,其实这段代码并没有错,但是 php 的 md5 函数默认返回的是 32位小写 ,而以上这一段返回的是 16位小写

于是想办法把这个 func 改为 32位小写输出即可

public static string md5(string s)
{
  md5 md5 = new md5cryptoserviceprovider();
  byte[] bytes = system.text.encoding.utf8.getbytes(s);
  bytes = md5.computehash(bytes);
  md5.clear();

  string ret = "";
  for (int i = 0; i < bytes.length; i++)
  {
    ret += convert.tostring(bytes[i], 16).padleft(2, '0');
  }
  return ret.padleft(32, '0');
}

总结

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作能带来一定的帮助,如果有疑问大家可以留言交流。

如对本文有疑问, 点击进行留言回复!!

相关文章:

验证码:
移动技术网