【加密算法】MD5

1、简介算法

MD5的全称是Message-Digest Algorithm 5(信息摘要算法),在90年代初由MIT Laboratory for Computer Science和RSA Data Security Inc的Ronald L. Rivest开发出来,经MD二、MD3和MD4发展而来。网络

消息摘要算法的主要特征是加密过程不须要密钥,而且通过加密的数据没法被解密,只有输入相同的明文数据通过相同的消息摘要算法才能获得相同的密文。消息摘要算法不存在密钥的管理与分发问题,适合于分布式网络上使用。因为其加密计算的工做量至关可观,因此之前的这种算法一般只用于数据量有限的状况下的加密,例如计算机的口令就是用不可逆加密算法加密的。近年来,随着计算机性能的飞速改善,加密速度再也不成为限制这种加密技术发展的桎梏,于是消息摘要算法应用的领域不断增长。分布式

2、实现ide

/// <summary>
/// MD5加密类
/// </summary>
public class Md5Helper
{
    /// <summary>
    /// MD5加密
    /// 加权:无
    /// 位数:32位
    /// </summary>
    /// <param name="plaintext">明文</param>
    /// <returns>返回32位的密文</returns>
    public static string Encrypt(string plaintext)
    {
        return Encrypt(plaintext, true, null);
    }

    /// <summary>
    /// MD5加密
    /// 加权:有
    /// 位数:32位
    /// </summary>
    /// <param name="plaintext">明文</param>
    /// <param name="salt">随机字符串</param>
    /// <returns>返回32位的密文</returns>
    public static string Encrypt(string plaintext, string salt)
    {
        return Encrypt(plaintext, true, salt);
    }

    /// <summary>
    /// MD5加密
    /// 加权:无
    /// 位数:32位或16位
    /// </summary>
    /// <param name="plaintext">明文</param>
    /// <param name="isThirtyTwo">是 返回32位,否返回16位</param>
    /// <returns></returns>
    public static string Encrypt(string plaintext, bool isThirtyTwo)
    {
        return Encrypt(plaintext, isThirtyTwo, null);
    }

    /// <summary>
    /// MD5加密
    /// 加权:有
    /// 位数:32位或16位
    /// </summary>
    /// <param name="plaintext"></param>
    /// <param name="isThirtyTwo"></param>
    /// <param name="salt"></param>
    /// <returns></returns>
    public static string Encrypt(string plaintext, bool isThirtyTwo, string salt)
    {
        if (String.IsNullOrEmpty(plaintext))
        {
            throw new ArgumentNullException("明文不能为空");
        }

        if (!String.IsNullOrEmpty(salt))
        {
            plaintext = plaintext + salt; //加权是为了增长密文的复杂性。 这里的加权位置可按照本身的须要任意调整
        }

        MD5CryptoServiceProvider md5 = new MD5CryptoServiceProvider();
        byte[] bytResult = md5.ComputeHash(Encoding.UTF8.GetBytes(plaintext));
        md5.Clear();

        string result = String.Empty;
        if (isThirtyTwo)
        {
            result = BitConverter.ToString(bytResult);
        }
        else
        {
            result = BitConverter.ToString(bytResult, 4, 8);
        }
        return result.Replace("-", "");
    }
}
相关文章
相关标签/搜索