什么样在C#中变化与PHP一样的MD5 Hash Code

  目前在对一个现有的体系开展C#改造,该系统从前是用PHP做的,后台的领队登陆用的是MD5加密算法。在PHP中,要对一个字符串举办MD5加密非常简单,一行代码即可:

md5("Something you want to encrypt.")

  直接调用md5()方法,然后就要举办MD5加密的字符串传进去,就足以获取重临的hash
code。在C#中应当也会有照应的算法吧!对啊?我先是尝试了下边的代码,结果取得的hash
code和PHP不一致。

public static string MD5(string stringToHash)
{
    return FormsAuthentication.HashPasswordForStoringInConfigFile(stringToHash, "md5");
}

  所以,我们不得不借用C#的MD5CryptoServiceProvider对象自己写代码举办转换。

  1.
实例化MD5CryptoServiceProvider对象

  2. 将字符串转换成byte数组

  3.
使用MD5CryptoServiceProvider目的的ComputeHash()方法将byte数组举行加密,再次回到转换后的byte数组

  4. 在讲byte数组转换成字符串在此以前,还亟需对其进展遍历并做如下转换:

myByte.ToString("x2").ToLower()

  然后,你才能获得和PHP中同样的MD5 hash
code。为何在.NET中要如此艰苦,或许这也是为什么那么多的开发人士仍旧热衷于PHP开发的说辞之一,每一门编程语言都有它本身的魅力,也都有它存在的意义!

  基于下面的座谈,完整的代码如下:

public static string MD5ForPHP(string stringToHash)
{
    var md5 = new System.Security.Cryptography.MD5CryptoServiceProvider();
    byte[] emailBytes = Encoding.UTF8.GetBytes(stringToHash.ToLower());
    byte[] hashedEmailBytes = md5.ComputeHash(emailBytes);
    StringBuilder sb = new StringBuilder();
    foreach (var b in hashedEmailBytes)
    {
        sb.Append(b.ToString("x2").ToLower());
    }
    return sb.ToString();
}

  或者,你也足以把下边的章程写成一个C#推而广之方法,只需要修改章程签名即可。

public static string MD5ForPHP(this String, string stringToHash)
{
    // Your code here.
}

  PHP程序和C#先后在不少地方都会提到到格式之间的转移,假如运行PHP的服务器是UNIX类型的,则还会设有日期格式之间的变换。下面的五个点子体现了怎么着将UNIX时间更换成C#
Date提姆e以及哪些将C# DateTime转换成UNIX时间。

public static DateTime UnixTimeStampToDateTime(long unixTimeStamp)
{
    // Unix timestamp is seconds past epoch
    DateTime dtDateTime = new DateTime(1970, 1, 1, 0, 0, 0, 0, System.DateTimeKind.Utc);
    return dtDateTime.AddSeconds(unixTimeStamp);
}

public static long DateTimeToUnixTimeStamp(DateTime datetime)
{
    TimeSpan span = (datetime - new DateTime(1970, 1, 1, 0, 0, 0, 0, DateTimeKind.Utc));
    return (long)span.TotalSeconds;
}

 

相关文章