#region MD5加密
/// <summary>
/// 16位MD5加密
/// </summary>
/// <param name="password"></param>
/// <returns></returns>
public static string MD5Encrypt16(string password)
{
var md5 = new MD5CryptoServiceProvider();
string t2 = BitConverter.ToString(md5.ComputeHash(Encoding.Default.GetBytes(password)), 4, 8);
t2 = t2.Replace("-", "");
return t2;
}
/// <summary>
/// 32位MD5加密
/// </summary>
/// <param name="password"></param>
/// <returns></returns>
public static string MD5Encrypt32(string password)
{
string cl = password;
string pwd = "";
MD5 md5 = MD5.Create(); //实例化一个md5对像
// 加密后是一个字节类型的数组,这里要注意编码UTF8/Unicode等的选择
byte[] s = md5.ComputeHash(Encoding.UTF8.GetBytes(cl));
// 通过使用循环,将字节类型的数组转换为字符串,此字符串是常规字符格式化所得
for (int i = 0; i < s.Length; i++)
{
// 将得到的字符串使用十六进制类型格式。格式后的字符是小写的字母,如果使用大写(X)则格式后的字符是大写字符
pwd = pwd + s[i].ToString("X");
}
return pwd;
}
public static string MD5Encrypt64(string password)
{
string cl = password;
//string pwd = "";
MD5 md5 = MD5.Create(); //实例化一个md5对像
// 加密后是一个字节类型的数组,这里要注意编码UTF8/Unicode等的选择
byte[] s = md5.ComputeHash(Encoding.UTF8.GetBytes(cl));
return Convert.ToBase64String(s);
}
private static string key = "abcd1234";//密文 加密解密是都需要密文且保持一致
private static string iv = "12345678";//加密解密时key 、 iv 中传入的key、iv值一致
public static string Des_Encrypt(string encryptString)
{
DESCryptoServiceProvider des = new DESCryptoServiceProvider();
byte[] sor = Encoding.UTF8.GetBytes(encryptString);
//传入key、iv
des.Key = UTF8Encoding.UTF8.GetBytes(key);
des.IV = UTF8Encoding.UTF8.GetBytes(iv);
MemoryStream ms = new MemoryStream();
CryptoStream cs = new CryptoStream(ms, des.CreateEncryptor(), CryptoStreamMode.Write);
cs.Write(sor, 0, sor.Length);
cs.FlushFinalBlock();
StringBuilder sb = new StringBuilder();
foreach (byte b in ms.ToArray())
{
sb.AppendFormat("{0:X2}", b);
}
return sb.ToString();
}
public static string DES_Decrypts(string pToDecrypt)
{
DESCryptoServiceProvider des = new DESCryptoServiceProvider();
byte[] inputByteArray = new byte[pToDecrypt.Length / 2];
for (int x = 0; x < pToDecrypt.Length / 2; x++)
{
int i = (Convert.ToInt32(pToDecrypt.Substring(x * 2, 2), 16));
inputByteArray[x] = (byte)i;
}
des.Key = UTF8Encoding.UTF8.GetBytes(key);//***************key与加密时的Key保持一致
des.IV = UTF8Encoding.UTF8.GetBytes(iv);//*****************skey与加密时的IV保持一致
MemoryStream ms = new MemoryStream();
CryptoStream cs = new CryptoStream(ms, des.CreateDecryptor(), CryptoStreamMode.Write);
cs.Write(inputByteArray, 0, inputByteArray.Length);
cs.FlushFinalBlock();
StringBuilder ret = new StringBuilder();
return Encoding.UTF8.GetString(ms.ToArray());
}
#endregion
测试:
#region MD5加密
string password = "123";
Console.WriteLine("md5十六位小写加密:"+MD5Encrypt16(password).ToLower());
Console.WriteLine("md5十六位大写加密:"+MD5Encrypt16(password).ToUpper());
Console.WriteLine("md5三十二位小写加密:"+MD5Encrypt32(password).ToLower());
Console.WriteLine("md5三十二位大写加密:" + MD5Encrypt32(password).ToUpper());
Console.WriteLine("md5六十四位小写加密:" + MD5Encrypt64(password).ToLower());
Console.WriteLine("md5六十四位大写加密:" + MD5Encrypt64(password).ToUpper());
//DES 加密解密
string value = "张三";
Console.WriteLine("解密内容:"+value);
Console.WriteLine("des加密结果:"+Des_Encrypt(value));
Console.WriteLine("des解密结果:"+DES_Decrypts(Des_Encrypt(value)));
#endregion
输出结果:
与实际做对比: