zoukankan      html  css  js  c++  java
  • MD5加密

    MD5全称是message-digest algorithm 5,MD5是一个单向加密(只能加密,不能解密(网上有暴力解密的,成功率很小))

    MD5主要用途:

    1、对一段信息生成信息摘要,该摘要对该信息具有唯一性,可以作为数字签名

    2、用于验证文件的有效性(是否有丢失或损坏的数据)

    3、对用户密码的加密

    4、在哈希函数中计算散列值

    5、安全性高

    由于算法的某些不可逆特征,在加密应用上有较好的安全性。通过使用MD5加密算法,我们输入一个任意长度的字节串,都会生成一个128位的整数。所以根据这一点MD5被广泛的用作密码加密。

    需要引入命名空间

    using System.Security;

    using System.Security.Cryptography;

    直接上代码

            /// <summary>
            ///  md5加密返回一个128位整数的方法
            /// </summary>
            /// <param name="strs">需要加密的明文</param>
            /// <returns></returns>
            public static  string ToMD5(string strs)
            {
                MD5 md5 = new MD5CryptoServiceProvider();
                byte[] bytes = Encoding.Default.GetBytes(strs);//将要加密的字符串转换为字节数组
                byte[] encryptdata = md5.ComputeHash(bytes);//将字符串加密后也转换为字符数组
                return Convert.ToBase64String(encryptdata);//将加密后的字节数组转换为加密字符串
            }
            /// <summary>
            /// 创建哈希字符串适用于任何 MD5 哈希函数 (在任何平台) 上创建 32 个字符的十六进制格式哈希字符串
            /// </summary>
            /// <param name="source">需要加密的明文</param>
            /// <returns></returns>
            public static string Get32MD5_One(string source)
            {
                using (System.Security.Cryptography.MD5 md5Hash = System.Security.Cryptography.MD5.Create())
                {
                    byte[] data = md5Hash.ComputeHash(System.Text.Encoding.UTF8.GetBytes(source));
                    System.Text.StringBuilder sBuilder = new System.Text.StringBuilder();
                    for (int i = 0; i < data.Length; i++)
                    {
                        sBuilder.Append(data[i].ToString("x2"));
                    }
    
                    string hash = sBuilder.ToString();
                    return hash.ToUpper();
                }
            }
            /// <summary>
            /// 获取32位md5加密Two
            /// </summary>
            /// <param name="strSource">需要加密的明文</param>
            /// <returns>返回32位加密结果,该结果取32位加密结果的第9位到25位</returns>
            public static string Get32MD5_Two(string source)
            {
                System.Security.Cryptography.MD5 md5 = new System.Security.Cryptography.MD5CryptoServiceProvider();
                //获取密文字节数组
                byte[] bytResult = md5.ComputeHash(System.Text.Encoding.Default.GetBytes(source));
                //转换成字符串,32位
                string strResult = BitConverter.ToString(bytResult);
                //BitConverter转换出来的字符串会在每个字符中间产生一个分隔符,需要去除掉
                strResult = strResult.Replace("-", "");
                return strResult.ToUpper();
            }
            /// <summary>
            /// 获取16位md5加密One
            /// </summary>
            /// <param name="source">需要加密的明文</param>
            /// <returns></returns>
            public static string Get16MD5_One(string source)
            {
                using (System.Security.Cryptography.MD5 md5Hash = System.Security.Cryptography.MD5.Create())
                {
                    byte[] data = md5Hash.ComputeHash(System.Text.Encoding.UTF8.GetBytes(source));
                    //转换成字符串,并取9到25位
                    string sBuilder = BitConverter.ToString(data, 4, 8);
                    //BitConverter转换出来的字符串会在每个字符中间产生一个分隔符,需要去除掉
                    sBuilder = sBuilder.Replace("-", "");
                    return sBuilder.ToString().ToUpper();
                }
            }
            /// <summary>
            /// 获取16位md5加密Two
            /// </summary>
            /// <param name="strSource">需要加密的明文</param>
            /// <returns>返回16位加密结果,该结果取32位加密结果的第9位到25位</returns>
            public static string Get16MD5(string source)
            {
                System.Security.Cryptography.MD5 md5 = new System.Security.Cryptography.MD5CryptoServiceProvider();
                //获取密文字节数组
                byte[] bytResult = md5.ComputeHash(System.Text.Encoding.Default.GetBytes(source));
                //转换成字符串,并取9到25位
                string strResult = BitConverter.ToString(bytResult, 4, 8);
                //BitConverter转换出来的字符串会在每个字符中间产生一个分隔符,需要去除掉
                strResult = strResult.Replace("-", "");
                return strResult.ToUpper();
            }
  • 相关阅读:
    MLlib--FPGrowth算法
    MLlib--SVD算法
    算法--访问单个节点的删除
    算法--环形链表插值
    算法--数组变树
    算法--滑动窗口
    RMAN备份失败之:mount: block device /dev/emcpowerc1 is write-protected, mounting read-only
    OPatch failed with error code 73
    Sybase ASE报错:server Error: 8242, Severity: 16, State: 1
    ORA-00257: archiver error. Connect internal only, until freed
  • 原文地址:https://www.cnblogs.com/loushengjie/p/11211564.html
Copyright © 2011-2022 走看看