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加密的主要内容,如果未能解决你的问题,请参考以下文章