日常程序开发中,涉及到敏感数据内容,通常会采取加密处理以保证数据安全,本篇文章讲述了在C#中使用MD5方法加密数据


MD5介绍

MD5的全称是message-digest algorithm 5,MD5算法属于hash算法的一类,对消息进行运算,产生一个128位的消息摘要(32位数字字母),并且加密不可逆,相同数据的加密结果一定相同。

特点

  • 任意长度的数据,算出的MD5值都是固定的长度
  • 计算容易
  • 无论对原来的数据进行多细小的改动,所得到的MD5都有很大差别
  • 弱抗碰撞:已知原数据和其MD5值,想找到一个具有相同MD5值的数据是非常困难的。
  • 强抗碰撞:想找到两个不同的数据,使它们具有相同的MD5值,是非常困难的。

MD5解密

MD5数据是不可逆的,网上的破解工具都基于大数据解密,将大量数据的MD5值先保存起来,对于一些简单的数据,是很容易匹配到的。

使用场景

  • 用户的密码,身份信息,等等一些不愿意展示明文的数据
  • 数字签名
  • 检验双方数据文件是否一致,防篡改

C#中实现MD5加密

  1. C#中提供 MD5CryptoServiceProvider 和 MD5 两个类型提供对MD5的加密操作,其中 MD5CryptoServiceProvider 是 MD5 的派生类。
  2. 在.NET6中 MD5CryptoServiceProvider 会提示已过时,在使用的时候,以上两个类都可以去使用,但在.NET6及以上版本中会提示过时,因此建议使用 MD5 来操作。

C#代码实现

  1. MD5CryptoServiceProvider实例化,并对数据进行加密
 string Str = "要加密的字符串";
 var md5 = new MD5CryptoServiceProvider();//实例化
 //将要加密的字符串转换成字节数组
 byte[] strbt = Encoding.UTF8.GetBytes(Str)
 //对转换后的字节进行MD5加密
 byte[] result = md5.ComputeHash(strbt);
  
  1. MD5实例化,并对数据进行加密
 string Str = "要加密的字符串";
 MD5 md5 = MD5.Create();//实例化
 //将要加密的字符串转换成字节数组
 byte[] strbt = Encoding.UTF8.GetBytes(Str)
 //对转换后的字节进行MD5加密
 byte[] result = md5.ComputeHash(strbt);
  1. 上面代码中。两个类的使用方法基本一致,result为加密后产生的字节数组,长度为16
  2. 加密后将字节转换为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位字符串。
  1. 实际使用中有时会有16位和32位区分,实际16位是由32位,去除前后8位后所得到的16位字符串,其中BitConverter.ToString(result,4,12);可以直接返回16位的值
  2. 上面方法主要以字符串为例,进行加密的演示,在实际中,文件、图片等其他数据也都可以转换成字节数组进行加密。