把写代码过程重要的代码片段做个备份,如下代码段是关于C#自定义基于Base64的加密解密类的代码,希望对大伙有用途。
using System;
using System.Security.Cryptography;
using System.Text;
namespace DotNet.Utilities
{
public class DEncrypt
{
public DEncrypt()
{
}
#region 使用 缺省密钥字符串 加密/解密string
public static string Encrypt(string original)
{
}
public static string Decrypt(string original)
{
}
#endregion
#region 使用 给定密钥字符串 加密/解密string
public static string Encrypt(string original, string key)
{
byte[] buff = System.Text.Encoding.Default.GetBytes(original);
byte[] kb = System.Text.Encoding.Default.GetBytes(key);
return Convert.ToBase64String(Encrypt(buff,kb));
}
public static string Decrypt(string original, string key)
{
return Decrypt(original,key,System.Text.Encoding.Default);
}
public static string Decrypt(string encrypted, string key,Encoding encoding)
{
byte[] buff = Convert.FromBase64String(encrypted);
byte[] kb = System.Text.Encoding.Default.GetBytes(key);
return encoding.GetString(Decrypt(buff,kb));
}
#endregion
#region 使用 缺省密钥字符串 加密/解密/byte[]
public static byte[] Decrypt(byte[] encrypted)
{
return Decrypt(encrypted,key);
}
public static byte[] Encrypt(byte[] original)
{
return Encrypt(original,key);
}
#endregion
#region 使用 给定密钥 加密/解密/byte[]
public static byte[] MakeMD5(byte[] original)
{
MD5CryptoServiceProvider hashmd5 = new MD5CryptoServiceProvider();
byte[] keyhash = hashmd5.ComputeHash(original);
hashmd5 = null;
return keyhash;
}
public static byte[] Encrypt(byte[] original, byte[] key)
{
TripleDESCryptoServiceProvider des = new TripleDESCryptoServiceProvider();
des.Key = MakeMD5(key);
des.Mode = CipherMode.ECB;
return des.CreateEncryptor().TransformFinalBlock(original, 0, original.Length);
}
public static byte[] Decrypt(byte[] encrypted, byte[] key)
{
TripleDESCryptoServiceProvider des = new TripleDESCryptoServiceProvider();
des.Key = MakeMD5(key);
des.Mode = CipherMode.ECB;
return des.CreateDecryptor().TransformFinalBlock(encrypted, 0, encrypted.Length);
}
#endregion
}
}