using NCC.Dependency; using System; using System.IO; using System.Security.Cryptography; using System.Text; namespace NCC.DataEncryption { /// /// DESC 加解密 /// [SuppressSniffer] public class DESCEncryption { /// /// 加密 /// /// 加密文本 /// 密钥 /// 是否输出大写加密,默认 false /// public static string Encrypt(string text, string skey, bool uppercase = false) { using var des = DES.Create(); byte[] inputByteArray; inputByteArray = Encoding.Default.GetBytes(text); des.Key = Encoding.ASCII.GetBytes(MD5Encryption.Encrypt(skey, uppercase).Substring(0, 8)); des.IV = Encoding.ASCII.GetBytes(MD5Encryption.Encrypt(skey, uppercase).Substring(0, 8)); using var ms = new MemoryStream(); using var cs = new CryptoStream(ms, des.CreateEncryptor(), CryptoStreamMode.Write); cs.Write(inputByteArray, 0, inputByteArray.Length); cs.FlushFinalBlock(); var ret = new StringBuilder(); foreach (var b in ms.ToArray()) { ret.AppendFormat("{0:X2}", b); } return ret.ToString(); } /// /// 解密 /// /// 加密后字符串 /// 密钥 /// 是否输出大写加密,默认 false /// public static string Decrypt(string hash, string skey, bool uppercase = false) { using var des = DES.Create(); int len; len = hash.Length / 2; var inputByteArray = new byte[len]; int x, i; for (x = 0; x < len; x++) { i = Convert.ToInt32(hash.Substring(x * 2, 2), 16); inputByteArray[x] = (byte)i; } des.Key = Encoding.ASCII.GetBytes(MD5Encryption.Encrypt(skey, uppercase).Substring(0, 8)); des.IV = Encoding.ASCII.GetBytes(MD5Encryption.Encrypt(skey, uppercase).Substring(0, 8)); using var ms = new MemoryStream(); using var cs = new CryptoStream(ms, des.CreateDecryptor(), CryptoStreamMode.Write); cs.Write(inputByteArray, 0, inputByteArray.Length); cs.FlushFinalBlock(); return Encoding.Default.GetString(ms.ToArray()); } } }