我是靠谱客的博主 雪白月饼,最近开发中收集的这篇文章主要介绍C#与PHP的md5计算结果不同的解决方法,觉得挺不错的,现在分享给大家,希望可以做个参考。

概述

问题重现

这个 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');
}

总结

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

最后

以上就是雪白月饼为你收集整理的C#与PHP的md5计算结果不同的解决方法的全部内容,希望文章能够帮你解决C#与PHP的md5计算结果不同的解决方法所遇到的程序开发问题。

如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。

本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
点赞(117)

评论列表共有 0 条评论

立即
投稿
返回
顶部