.NET TripleDES加密、解密
2009-12-14 16:37
267 查看
using System; using System.Security.Cryptography; using System.Text; namespace Lib { /// <summary> /// TripleDes加密、解密byte[]、string /// </summary> public class TripleDesEncrypt { /// <summary> /// 构造方法 /// </summary> public TripleDesEncrypt() { } #region 使用 缺省密钥字符串 加密/解密string /// <summary> /// 使用缺省密钥字符串加密 /// </summary> /// <param name="original">明文</param> /// <returns>密文</returns> public static string Encrypt(string original) { return Encrypt(original, "Microsoft"); } /// <summary> /// 使用缺省密钥字符串解密 /// </summary> /// <param name="original">密文</param> /// <returns>明文</returns> public static string Decrypt(string original) { return Decrypt(original, "Microsoft", System.Text.Encoding.Default); } #endregion #region 使用 给定密钥字符串 加密/解密string /// <summary> /// 使用给定密钥字符串加密 /// </summary> /// <param name="original">原始文字</param> /// <param name="key">密钥</param> /// <returns>密文</returns> 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)); } /// <summary> /// 使用给定密钥字符串解密 /// </summary> /// <param name="original">密文</param> /// <param name="key">密钥</param> /// <returns>明文</returns> public static string Decrypt(string original, string key) { return Decrypt(original, key, System.Text.Encoding.Default); } /// <summary> /// 使用给定密钥字符串解密,返回指定编码方式明文 /// </summary> /// <param name="encrypted">密文</param> /// <param name="key">密钥</param> /// <param name="encoding">字符编码方案</param> /// <returns>明文</returns> 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[] /// <summary> /// 使用缺省密钥字符串解密 /// </summary> /// <param name="encrypted">密文</param> /// <param name="key">密钥</param> /// <returns>明文</returns> public static byte[] Decrypt(byte[] encrypted) { byte[] key = System.Text.Encoding.Default.GetBytes("Microsoft"); return Decrypt(encrypted, key); } /// <summary> /// 使用缺省密钥字符串加密 /// </summary> /// <param name="original">原始数据</param> /// <param name="key">密钥</param> /// <returns>密文</returns> public static byte[] Encrypt(byte[] original) { byte[] key = System.Text.Encoding.Default.GetBytes("Microsoft"); return Encrypt(original, key); } #endregion #region 使用 给定密钥 加密/解密/byte[] /// <summary> /// 生成MD5摘要 /// </summary> /// <param name="original">数据源</param> /// <returns>摘要</returns> public static byte[] MakeMD5(byte[] original) { MD5CryptoServiceProvider hashmd5 = new MD5CryptoServiceProvider(); byte[] keyhash = hashmd5.ComputeHash(original); hashmd5 = null; return keyhash; } /// <summary> /// 使用给定密钥加密 /// </summary> /// <param name="original">明文</param> /// <param name="key">密钥</param> /// <returns>密文</returns> 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); } /// <summary> /// 使用给定密钥加密 /// </summary> /// <param name="original">明文</param> /// <param name="sKey">密钥</param> /// <returns>密文</returns> public static byte[] Encrypt(byte[] original, string sKey) { byte[] key = System.Text.Encoding.Default.GetBytes(sKey); return Encrypt(original, key); } /// <summary> /// 使用给定密钥解密数据 /// </summary> /// <param name="encrypted">密文</param> /// <param name="key">密钥</param> /// <returns>明文</returns> 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); } /// <summary> /// 使用给定密钥解密数据 /// </summary> /// <param name="encrypted">密文</param> /// <param name="sKey">密钥</param> /// <returns>明文</returns> public static byte[] Decrypt(byte[] encrypted, string sKey) { byte[] key = System.Text.Encoding.Default.GetBytes(sKey); return Decrypt(encrypted, key); } #endregion } }
相关文章推荐
- .NET中的加密解密:私钥加密(对称加密):DES
- Asp.Net C#中除了MD5加密之外还经常用到了AES加密、解密与DES加密、解密,本次先介绍DES的加密及解密。注意的是DES的密匙是8位的。
- 【转】asp.net(c#)加密解密算法之sha1、md5、des、aes实现源码详解
- TripleDESCryptoServiceProvider 加密解密
- VB.NET 的 DES 加密与解密(转载于nofort博客)
- NET实现RSA AES DES 字符串 加密解密以及SHA1 MD5加密
- Java加密解密DESUtil、TripleDESUtil(未测试)
- Android平台和java平台 DES、3DES、RSA加密解密互通程序及其不能互通的原因
- DES的加密与解密(可逆)
- asp.net配置文件connectionStrings加密和解密
- des文件加密、解密
- 说一说ASP.NET web.config 加密及解密方法 (代码)
- C#.NET 加密解密:AES/DES/Base64/RSA/MD5/SHA256
- C#中使用DES和AES加密解密
- 网络上DesUtil.java关于汉字加密解密出现乱码的问题
- java加密解密___des的简单实现
- PHP使用DES进行加密和解密
- RSA和DES------加密和解密类
- java加密解密初探-DES
- DES、RSA、MD5、SHA、随机生成加密与解密