//默认密钥向量
private static readonly byte[] Keys = { 0x12, 0x34, 0x56, 0x78, 0x90, 0xAB, 0xCD, 0xEF };
/// <summary>
/// DES加密字符串
/// </summary>
/// <param name="encryptString">待加密的字符串</param>
/// <returns>加密成功返回加密后的字符串,失败返回源串</returns>
public static string EncryptString(string encryptString)
{
try
{
const string encryptKey = "sdkekdjf";//密钥
var rgbKey = Encoding.UTF8.GetBytes(encryptKey.Substring(0, 8)); //把密钥转换成字节数组
var rgbIv = Keys;//向量
var inputByteArray = Encoding.UTF8.GetBytes(encryptString);//将转换为字节数组
var dCsp = new DESCryptoServiceProvider();//声明一个DES对象
var mStream = new MemoryStream();//开辟一块内存流
var cStream = new CryptoStream(mStream, dCsp.CreateEncryptor(rgbKey, rgbIv), CryptoStreamMode.Write);//把内存流对象包装成加密流对象
cStream.Write(inputByteArray, 0, inputByteArray.Length);//将明文写入加密流中
cStream.FlushFinalBlock();
return Convert.ToBase64String(mStream.ToArray()).Replace("+", "yu");
}
catch
{
return encryptString;
}
}
/// <summary>
/// DES解密字符串
/// </summary>
/// <param name="decryptString">待解密的字符串</param>
/// <returns>解密成功返回解密后的字符串,失败返源串</returns>
public static string DecryptString(string decryptString)
{
try
{
const string decryptKey = "sdkekdjf";//密钥
var rgbKey = Encoding.UTF8.GetBytes(decryptKey);//密钥转换为字节数组
var rgbIv = Keys;//解密向量
var inputByteArray = Convert.FromBase64String(decryptString.Replace("yu", "+"));
//var 1=Convert .FromBase64CharArray();
var dcsp = new DESCryptoServiceProvider();
var mStream = new MemoryStream();
var 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;
}
}