using System.Security.Cryptography;
using System.IO;
using System.Text;ide
//默認密鑰向量
private static byte[] DyncKeys = { 0x12, 0x14, 0x14, 0x15, 0xA0, 0xA1, 0xB0, 0xB1 };
//默認加密密鑰
private static byte[] Key = { 0x01, 0x02, 0x03, 0x04, 0xA0, 0xAB, 0xAC, 0xAD };加密
/// <summary>
/// DES加密字符串/// </summary>
/// <param name="encryptString">待加密的字符串</param>
/// <param name="encryptKey">加密密鑰,要求爲8位</param>
/// <returns>加密成功返回加密後的字符串,失敗返回源串</returns>
public static string EncryptDES(string encryptString, byte[] encryptKey)
{
try
{
byte[] rgbKey = encryptKey;
byte[] rgbIV = DyncKeys;
byte[] inputByteArray = Encoding.UTF8.GetBytes(encryptString);
DESCryptoServiceProvider dCSP = new DESCryptoServiceProvider();
MemoryStream mStream = new MemoryStream();
CryptoStream cStream = new CryptoStream(mStream, dCSP.CreateEncryptor(rgbKey, rgbIV), CryptoStreamMode.Write);
cStream.Write(inputByteArray, 0, inputByteArray.Length);
cStream.FlushFinalBlock();
return Convert.ToBase64String(mStream.ToArray());
}
catch
{
return encryptString;
}
}字符串
/// <summary>
/// DES解密字符串/// </summary>
/// <param name="decryptString">待解密的字符串</param>
/// <param name="decryptKey">解密密鑰,要求爲8位,和加密密鑰相同</param>
/// <returns>解密成功返回解密後的字符串,失敗返源串</returns>
public static string DecryptDES(string decryptString, byte[] decryptKey)
{
try
{
byte[] rgbKey = decryptKey;
byte[] rgbIV = DyncKeys;
byte[] inputByteArray = Convert.FromBase64String(decryptString);
DESCryptoServiceProvider DCSP = new DESCryptoServiceProvider();
MemoryStream mStream = new MemoryStream();
CryptoStream cStream = new CryptoStream(mStream, DCSP.CreateDecryptor(rgbKey, rgbIV), CryptoStreamMode.Write);
cStream.Write(inputByteArray, 0, inputByteArray.Length);
cStream.FlushFinalBlock();
return Encoding.UTF8.GetString(mStream.ToArray());
}
catch
{
return decryptString;
}
} input