MD5加密

Posted 楚弋川

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了MD5加密相关的知识,希望对你有一定的参考价值。


(1) MD5算法是一种散列(hash)算法(摘要算法,指纹算法),不是一种加密算法,任何长度的任意内容都可以用MD5计算出散列值

(2)无论字符串还是文件都可以计算MD5值,无论字符串长短,还是文件大或者小,计算出来的MD5值得位数相同

(3)不可逆,不可能根据现有的MD5值,计算出原来的字符串是什么

(4)不可重复性(理论上可以重复,但是几率很小)

(5)MD5算法理论上是不可逆的,因此攻击的唯一办法就是碰撞,两个不同的内容生成相同的MD5值,这就是碰撞

using System.Security.Cryptography;        
static string GetMD5(string str, int code)
        
            string convertStr = null;
            MD5 md5 = MD5.Create();//实例化一个MD5对象,也可以这样:
            //MD5CryptoServiceProvider md5 = new MD5CryptoServiceProvider();
            if (code == 16)//16位加密
            
                byte[] value = Encoding.GetEncoding("UTF-8").GetBytes(str);//将字符串转化为UTF8格式的字节数组
                byte[] data = md5.ComputeHash(value);//计算指定数组的哈希值
                string byteToStr = BitConverter.ToString(data);//将字节数组转换为字符串
                convertStr = byteToStr.Replace("-","").Substring(8, 16);//移除字符串中的“-”,并从第8位开始,截取16位字符
            
            else if (code == 32)//32位加密
            
                byte[] value = UTF8Encoding.Default.GetBytes(str);
                byte[] data = md5.ComputeHash(value);//使用十六进制类型格式
                StringBuilder sb = new StringBuilder();
                for (int i = 0; i < data.Length; i++)
                
                    sb.Append(data[i].ToString("x2"));//直接ToString()后的字符是小写的字母,如果使用大写则格式为ToString("X")
                
                convertStr = sb.ToString();
            
            return convertStr;
       

以上是关于MD5加密的主要内容,如果未能解决你的问题,请参考以下文章

关于MD5加密过的字符串的解密

MD5加密会产生16位跟32位的结果?

MD5加密会产生16位跟32位的结果?

MD5是怎么加密的?

asp版密码进行md5加密

md5 加密,既然无法解密,那这个加密的意义有啥呢? 对文件加密后怎么返回原值呢?