using System; using System.Collections.Generic; using System.IO; using System.Security.Cryptography; using System.Text; namespace Admin.Core.Common { /// /// DES算法加密解密 /// public class DESProvider { private DESProvider() { } //默认的初始化密钥 private static string key = "Microsoft"; #region 对称加密解密的密钥 /// /// 对称加密解密的密钥 /// public static string Key { get { return key; } set { key = value; } } #endregion #region 加密 /// /// 采用DES算法对字符串加密 /// /// 要加密的字符串 /// 加密的密钥 /// public static string EncryptString(string encryptString, string key) { //加密加密字符串是否为空 if (string.IsNullOrEmpty(encryptString)) { throw new ArgumentNullException("encryptString", "不能为空"); } //加查密钥是否为空 if (string.IsNullOrEmpty(key)) { throw new ArgumentNullException("key", "不能为空"); } //将密钥转换成字节数组 var keyBytes = Encoding.UTF8.GetBytes(key); //设置初始化向量 var keyIV = keyBytes; //将加密字符串转换成UTF8编码的字节数组 var inputByteArray = Encoding.UTF8.GetBytes(encryptString); //调用EncryptBytes方法加密 var resultByteArray = EncryptBytes(inputByteArray, keyBytes, keyIV); //将字节数组转换成字符串并返回 return Convert.ToBase64String(resultByteArray); } /// /// DES加密 /// /// 要加密的字符串 /// public static string EncryptString(string encryptString) { return EncryptString(encryptString, key); } /// /// 采用DES算法对字节数组加密 /// /// 要加密的字节数组 /// 算法的密钥,长度为8的倍数,最大长度64 /// 算法的初始化向量,长度为8的倍数,最大长度64 /// public static byte[] EncryptBytes(byte[] sourceBytes, byte[] keyBytes, byte[] keyIV) { if (sourceBytes == null || keyBytes == null || keyIV == null) { throw new ArgumentNullException("sourceBytes和keyBytes", "不能为空。"); } else { //检查密钥数组长度是否是8的倍数并且长度是否小于64 keyBytes = CheckByteArrayLength(keyBytes); //检查初始化向量数组长度是否是8的倍数并且长度是否小于64 keyIV = CheckByteArrayLength(keyIV); var provider = new DESCryptoServiceProvider(); //实例化内存流MemoryStream var mStream = new MemoryStream(); //实例化CryptoStream var cStream = new CryptoStream(mStream, provider.CreateEncryptor(keyBytes, keyIV), CryptoStreamMode.Write); cStream.Write(sourceBytes, 0, sourceBytes.Length); cStream.FlushFinalBlock(); //将内存流转换成字节数组 var buffer = mStream.ToArray(); mStream.Close();//关闭流 cStream.Close();//关闭流 return buffer; } } #endregion #region 解密 public static string DecryptString(string decryptString, string key) { if (string.IsNullOrEmpty(decryptString)) { throw new ArgumentNullException("decryptString", "不能为空"); } if (string.IsNullOrEmpty(key)) { throw new ArgumentNullException("key", "不能为空"); } var keyBytes = Encoding.UTF8.GetBytes(key); var keyIV = keyBytes; //将解密字符串转换成Base64编码字节数组 var inputByteArray = Convert.FromBase64String(decryptString); //调用DecryptBytes方法解密 var resultByteArray = DecryptBytes(inputByteArray, keyBytes, keyIV); //将字节数组转换成UTF8编码的字符串 return Encoding.UTF8.GetString(resultByteArray); } /// /// DES解密 /// /// 要解密的字符串 /// public static string DecryptString(string decryptString) { return DecryptString(decryptString, key); } /// /// 采用DES算法对字节数组解密 /// /// 要加密的字节数组 /// 算法的密钥,长度为8的倍数,最大长度64 /// 算法的初始化向量,长度为8的倍数,最大长度64 /// public static byte[] DecryptBytes(byte[] sourceBytes, byte[] keyBytes, byte[] keyIV) { if (sourceBytes == null || keyBytes == null || keyIV == null) { throw new ArgumentNullException("soureBytes和keyBytes及keyIV", "不能为空。"); } else { //检查密钥数组长度是否是8的倍数并且长度是否小于64 keyBytes = CheckByteArrayLength(keyBytes); //检查初始化向量数组长度是否是8的倍数并且长度是否小于64 keyIV = CheckByteArrayLength(keyIV); var provider = new DESCryptoServiceProvider(); var mStream = new MemoryStream(); var cStream = new CryptoStream(mStream, provider.CreateDecryptor(keyBytes, keyIV), CryptoStreamMode.Write); cStream.Write(sourceBytes, 0, sourceBytes.Length); cStream.FlushFinalBlock(); //将内存流转换成字节数组 var buffer = mStream.ToArray(); mStream.Close();//关闭流 cStream.Close();//关闭流 return buffer; } } #endregion #region 检查密钥或初始化向量的长度,如果不是8的倍数或长度大于64则截取前8个元素 /// /// 检查密钥或初始化向量的长度,如果不是8的倍数或长度大于64则截取前8个元素 /// /// 要检查的数组 /// private static byte[] CheckByteArrayLength(byte[] byteArray) { var resultBytes = new byte[8]; //如果数组长度小于8 if (byteArray.Length < 8) { return Encoding.UTF8.GetBytes("12345678"); } //如果数组长度不是8的倍数 else if (byteArray.Length % 8 != 0 || byteArray.Length > 64) { Array.Copy(byteArray, 0, resultBytes, 0, 8); return resultBytes; } else { return byteArray; } } #endregion } }