public class DEncryptHelper
{
#region Md5加密
/// <summary>
/// 获取字符串MD5加密字符串
/// </summary>
/// <param name=”str”>原始字符串</param>
/// <returns>MD5加密字符串</returns>
public static string GetMd5(string str)
{
var pwd = System.Web.Security.FormsAuthentication.HashPasswordForStoringInConfigFile(str, “MD5”);
return pwd;
}
#endregion
#region 可逆加密 解密
/// <summary>
/// 加密方法
/// </summary>
/// <param name=”encryptionStr”>需要加密字符串</param>
/// <param name=”key”>密钥 8位 不够补0,超出截取</param>
/// <returns>加密后的字符串</returns>
public static string Encrypt(string encryptionStr, string key)
{
key = GetKey(key);
DESCryptoServiceProvider DES = new DESCryptoServiceProvider();
//把字符串放到byte数组中
//原来使用的UTF8编码,我改成Unicode编码了,不行
byte[] byt = Encoding.Default.GetBytes(encryptionStr);
//建立加密对象的密钥和偏移量
//使得输入密码必须输入英文文本
DES.Key = ASCIIEncoding.ASCII.GetBytes(key);
DES.IV = ASCIIEncoding.ASCII.GetBytes(key);
MemoryStream ms = new MemoryStream();
CryptoStream cs = new CryptoStream(ms, DES.CreateEncryptor(), CryptoStreamMode.Write);