MD5加密算法:单向不可逆加密;
MD5主要用途:
1、对一段信息生成信息摘要,该摘要对该信息具有唯一性,可以作为数字签名。
2、用于验证文件的有效性(是否有丢失或损坏的数据),
3、对用户密码的加密,
4、在哈希函数中计算散列值
从上边的主要用途中我们看到,由于算法的某些不可逆特征,在加密应用上有较好的安全性。通过使用MD5加密算法,我们输入一个任意长度的字节串,都会生成一个128位的整数。代码如下:
using System; using System.Text; using System.Security.Cryptography; namespace Common.Helper.Crypto { /// <summary> /// MD5加密 /// MD5全称是message-digest algorithm 5,单向的加密,无法根据密文推导出明文。 /// 应用:签名,文件校验 /// </summary> public static class MD5Encrypt { #region 枚举参数 /// <summary> /// 是否转化大小写 /// </summary> public enum IsUpper { ToUpper, ToLower }; /// <summary> /// 密文长度 /// </summary> public enum EncryptLength { I16, I32 }; #endregion #region 加密方法 /// <summary> /// MD5加密技术-【ToBase64|24】 /// </summary> /// <param name="palinData">明文</param> /// <param name="encodingType">编码方式</param> /// <returns>string:密文</returns> public static string EncryptToBase64(string palinData, EncodingStrOrByte.EncodingType encodingType = EncodingStrOrByte.EncodingType.UTF8, IsUpper isUpper = IsUpper.ToLower) { if (string.IsNullOrWhiteSpace(palinData)) return null; MD5 md5 = new MD5CryptoServiceProvider(); //实例化一个md5对像 byte[] bytes = EncodingStrOrByte.GetBytes(palinData, encodingType); //将要加密的字符串转换为指定编码的字节数组 byte[] hashVal = md5.ComputeHash(bytes);//将字符串加密后也转换为字符数组 string encryptData = string.Empty; //密文 switch (isUpper) { //将加密后的字节数组转换为base64编码加密字符串 case IsUpper.ToUpper: encryptData = Convert.ToBase64String(hashVal).ToUpper(); break; case IsUpper.ToLower: encryptData = Convert.ToBase64String(hashVal).ToLower(); break; } return encryptData; } /// <summary> /// MD5加密技术-【16|32】 /// </summary> /// <param name="palinData">明文</param> /// <param name="encodingType">编码方式</param> /// <param name="encryptLength">密文长度</param> /// <param name="isUpper">是否转化大小写</param> /// <returns>string:密文</returns> public static string Encrypt(string palinData, EncodingStrOrByte.EncodingType encodingType = EncodingStrOrByte.EncodingType.UTF8, EncryptLength encryptLength = EncryptLength.I32, IsUpper isUpper = IsUpper.ToLower) { if (string.IsNullOrWhiteSpace(palinData)) return null; MD5 md5 = MD5.Create();//实例化一个md5对像 byte[] bytes = EncodingStrOrByte.GetBytes(palinData, encodingType); //将要加密的字符串转换为指定编码的字节数组 byte[] hashVal = md5.ComputeHash(bytes);//将字符串加密后也转换为字符数组 StringBuilder sb = new StringBuilder(); switch (encryptLength) { case EncryptLength.I16: for (int i = 4; i < 12; i++) { sb.Append(hashVal[i].ToString("x2")); //16进制小写字符串,说明(x:小写字符串,X:大写字符串) } break; case EncryptLength.I32: for (int i = 0; i < 16; i++) { sb.Append(hashVal[i].ToString("x2")); } break; } string encryptData = string.Empty; //密文 switch (isUpper) { case IsUpper.ToUpper: encryptData = sb.ToString().ToUpper(); break; case IsUpper.ToLower: encryptData = sb.ToString().ToLower(); break; } return encryptData; } #endregion } }