C# 实现MD5加密
C# 实现MD5加密
C#MD5加密
日常程序开发中,涉及到敏感数据内容,通常会采取加密处理以保证数据安全,本篇文章讲述了在C#中使用MD5方法加密数据
MD5介绍
MD5的全称是message-digest algorithm 5,MD5算法属于hash算法的一类,对消息进行运算,产生一个128位的消息摘要(32位数字字母),并且加密不可逆,相同数据的加密结果一定相同。
特点
- 任意长度的数据,算出的MD5值都是固定的长度
- 计算容易
- 无论对原来的数据进行多细小的改动,所得到的MD5都有很大差别
- 弱抗碰撞:已知原数据和其MD5值,想找到一个具有相同MD5值的数据是非常困难的。
- 强抗碰撞:想找到两个不同的数据,使它们具有相同的MD5值,是非常困难的。
MD5解密
MD5数据是不可逆的,网上的破解工具都基于大数据解密,将大量数据的MD5值先保存起来,对于一些简单的数据,是很容易匹配到的。
使用场景
- 用户的密码,身份信息,等等一些不愿意展示明文的数据
- 数字签名
- 检验双方数据文件是否一致,防篡改
C#中实现MD5加密
- C#中提供 MD5CryptoServiceProvider 和 MD5 两个类型提供对MD5的加密操作,其中 MD5CryptoServiceProvider 是 MD5 的派生类。
- 在.NET6中 MD5CryptoServiceProvider 会提示已过时,在使用的时候,以上两个类都可以去使用,但在.NET6及以上版本中会提示过时,因此建议使用 MD5 来操作。
C#代码实现
- MD5CryptoServiceProvider实例化,并对数据进行加密
string Str = "要加密的字符串"; | |
var md5 = new MD5CryptoServiceProvider();//实例化 | |
//将要加密的字符串转换成字节数组 | |
byte[] strbt = Encoding.UTF8.GetBytes(Str) | |
//对转换后的字节进行MD5加密 | |
byte[] result = md5.ComputeHash(strbt); | |
- MD5实例化,并对数据进行加密
string Str = "要加密的字符串"; | |
MD5 md5 = MD5.Create();//实例化 | |
//将要加密的字符串转换成字节数组 | |
byte[] strbt = Encoding.UTF8.GetBytes(Str) | |
//对转换后的字节进行MD5加密 | |
byte[] result = md5.ComputeHash(strbt); |
- 上面代码中。两个类的使用方法基本一致,result为加密后产生的字节数组,长度为16
- 加密后将字节转换为32位数字和字母组成的字符,这里也是有两种方法
- BitConverter方法,此方法返回的字符串为16组,以 - 分割的,每组两位字符,如需要去除可以使用Replace去除
string StrResult = BitConverter.ToString(result); StrResult = StrResult.Replace("-", "");
- 循环字节数组转成字符串,其中ToString的参数中,X大写表示转换的字符也是大写,反之则为小写
string StrResult = ""; for (int i = 0; i < result.Length; i++) { StrResult = StrResult + result[i].ToString("X2"); }
- 通过上面方法,最终生成32位字符串。
- 实际使用中有时会有16位和32位区分,实际16位是由32位,去除前后8位后所得到的16位字符串,其中BitConverter.ToString(result,4,12);可以直接返回16位的值
- 上面方法主要以字符串为例,进行加密的演示,在实际中,文件、图片等其他数据也都可以转换成字节数组进行加密。
以上是C#实现MD5加密的全部内容,针对该方法已经整理成完整的帮助类,项目已上传至Gitee,可以直接下载使用
地址 :https://gitee.com/yang-yong-666/csharp
类文件:YYEnAndDecryption.MD5Decryption.cs
漫思