咋样在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提姆(Tim)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;
}

 

相关文章