public class DESCrypto
{
/// <summary>
/// 初始化des实例秘钥及向量
/// </summary>
/// <param name="key"></param>
/// <returns></returns>
private static DESCryptoServiceProvider InitDESInstance(string key)
{
DESCryptoServiceProvider des = new DESCryptoServiceProvider();
byte[] salt = new byte[] { 0x0A, 0x01, 0x02, 0x03, 0x04, 0x05, 0x06, 0xF1 };
byte[] keyByte = Encoding.UTF8.GetBytes(key);
Rfc2898DeriveBytes rfcKey = new Rfc2898DeriveBytes(keyByte, salt, );
Rfc2898DeriveBytes rfcIv = new Rfc2898DeriveBytes("", salt, );
des.Key = rfcKey.GetBytes();
des.IV = rfcIv.GetBytes();
return des;
} #region 基于Base64的加密解密(不其他格式的加解密方法配合使用)
/// <summary>
/// 基于Base64
/// </summary>
/// <param name="plaintext"></param>
/// <param name="key"></param>
/// <returns></returns>
public static string DESEncryptBase64(string plaintext,string key)
{
DESCryptoServiceProvider des = InitDESInstance(key);
byte[] dataByteArray = Encoding.UTF8.GetBytes(plaintext);
string ciphertext = "";
using (MemoryStream ms = new MemoryStream())
using (CryptoStream cs = new CryptoStream(ms, des.CreateEncryptor(), CryptoStreamMode.Write))
{
cs.Write(dataByteArray, , dataByteArray.Length);
cs.FlushFinalBlock();
ciphertext = Convert.ToBase64String(ms.ToArray());
}
return ciphertext;
} /// <summary>
/// 基于Base64
/// </summary>
/// <param name="encrypt"></param>
/// <param name="key"></param>
/// <returns></returns>
public static string DESDecryptBase64(string encrypt, string key)
{
DESCryptoServiceProvider des = InitDESInstance(key);
byte[] dataByteArray = Convert.FromBase64String(encrypt);
using (MemoryStream ms = new MemoryStream())
using (CryptoStream cs = new CryptoStream(ms, des.CreateDecryptor(), CryptoStreamMode.Write))
{
cs.Write(dataByteArray, , dataByteArray.Length);
cs.FlushFinalBlock();
return Encoding.UTF8.GetString(ms.ToArray());
}
}
#endregion #region 基于2位十六进制格式的加密解密(不其他格式的加解密方法配合使用)
/// <summary>
/// 加密
/// </summary>
/// <param name="plaintext">明文</param>
/// <param name="key"></param>
/// <returns></returns>
public static string DESEncrypt(string plaintext, string key)
{
DESCryptoServiceProvider des = InitDESInstance(key);
StringBuilder sb = new StringBuilder();
byte[] dataByteArray = Encoding.UTF8.GetBytes(plaintext);
string ciphertext = "";
using (MemoryStream ms = new MemoryStream())
using (CryptoStream cs = new CryptoStream(ms, des.CreateEncryptor(), CryptoStreamMode.Write))
{
cs.Write(dataByteArray, , dataByteArray.Length);
cs.FlushFinalBlock();
//输出加密文本
foreach (byte b in ms.ToArray())
{
sb.AppendFormat("{0:X2}", b);
}
ciphertext = sb.ToString();
}
return ciphertext; } /// <summary>
/// 解密
/// </summary>
/// <param name="ciphertext">密文</param>
/// <param name="key"></param>
/// <returns></returns>
public static string DESDecrypt(string ciphertext, string key)
{
DESCryptoServiceProvider des = InitDESInstance(key);
byte[] dataByteArray = new byte[ciphertext.Length / ];
for (int x = ; x < ciphertext.Length / ; x++)
{
int i = (Convert.ToInt32(ciphertext.Substring(x * , ), ));
dataByteArray[x] = (byte)i;
}
using (MemoryStream ms = new MemoryStream())
using (CryptoStream cs = new CryptoStream(ms, des.CreateDecryptor(), CryptoStreamMode.Write))
{
cs.Write(dataByteArray, , dataByteArray.Length);
cs.FlushFinalBlock();
return Encoding.UTF8.GetString(ms.ToArray());
}
}
#endregion #region 文件加密解密(不其他格式的加解密方法配合使用)
/// <summary>
/// 加密文件
/// </summary>
/// <param name="sourceFile">文件的物理路径</param>
/// <param name="encryptFile">文件的物理路径</param>
/// <param name="key"></param>
public static void DESEncryptFile(string sourceFile, string encryptFile, string key)
{
if (string.IsNullOrEmpty(sourceFile) || string.IsNullOrEmpty(encryptFile)||!File.Exists(sourceFile)) return; DESCryptoServiceProvider des = InitDESInstance(key); using (FileStream sourceStream = new FileStream(sourceFile, FileMode.Open, FileAccess.Read))
using (FileStream encryptStream = new FileStream(encryptFile, FileMode.Create, FileAccess.Write))
{
byte[] dataByteArray = new byte[sourceStream.Length];
sourceStream.Read(dataByteArray, , dataByteArray.Length);
using (CryptoStream cs = new CryptoStream(encryptStream, des.CreateEncryptor(), CryptoStreamMode.Write))
{
cs.Write(dataByteArray, , dataByteArray.Length);
cs.FlushFinalBlock();
}
}
} /// <summary>
/// 解密文件
/// </summary>
/// <param name="encryptFile">文件的物理路径</param>
/// <param name="decryptFile">文件的物理路径</param>
/// <param name="key"></param>
public static void DESDecryptFile(string encryptFile, string decryptFile, string key)
{
if (string.IsNullOrEmpty(encryptFile) || string.IsNullOrEmpty(decryptFile) || !File.Exists(encryptFile))return; DESCryptoServiceProvider des = InitDESInstance(key); using (FileStream encryptStream = new FileStream(encryptFile, FileMode.Open, FileAccess.Read))
using (FileStream decryptStream = new FileStream(decryptFile, FileMode.Create, FileAccess.Write))
{
byte[] dataByteArray = new byte[encryptStream.Length];
encryptStream.Read(dataByteArray, , dataByteArray.Length);
using (CryptoStream cs = new CryptoStream(decryptStream, des.CreateDecryptor(), CryptoStreamMode.Write))
{
cs.Write(dataByteArray, , dataByteArray.Length);
cs.FlushFinalBlock();
}
}
} /// <summary>
/// 加密文本并输出到文件
/// </summary>
/// <param name="plaintext"></param>
/// <param name="FileName">文件的物理路径</param>
/// <param name="Key"></param>
public static void DESEncryptTextToFile(string plaintext, string FileName, string key)
{
if (string.IsNullOrEmpty(FileName)) return; DESCryptoServiceProvider des = InitDESInstance(key);
byte[] dataByteArray = Encoding.UTF8.GetBytes(plaintext); using (FileStream fStream = File.Open(FileName, FileMode.Create))
using (CryptoStream cStream = new CryptoStream(fStream, des.CreateEncryptor(), CryptoStreamMode.Write))
{
cStream.Write(dataByteArray, , dataByteArray.Length);
cStream.FlushFinalBlock();
}
} /// <summary>
/// 解密文件中的密文并返回
/// </summary>
/// <param name="FileName"></param>
/// <param name="Key"></param>
/// <returns></returns>
public static string DESDecryptTextFromFile(string FileName, string key)
{
if (string.IsNullOrEmpty(FileName)||!File.Exists(FileName)) return ""; DESCryptoServiceProvider des = InitDESInstance(key); using (FileStream fStream = File.Open(FileName, FileMode.OpenOrCreate))
using (CryptoStream cStream = new CryptoStream(fStream, des.CreateDecryptor(), CryptoStreamMode.Read))
using (StreamReader sReader = new StreamReader(cStream))
{
string val = sReader.ReadToEnd();
return val;
}
}
#endregion
}

Tips:参考MSDN整理编写,比较全面。

DES加密解密帮助类的更多相关文章

  1. des 加密解密工具类

    最近在做des的双对称加密解密,特此记录一下. des对称加密,是一种比较传统的加密方式,其加密运算.解密运算使用的是同样的密钥,信息的发送者和信息的接收者在进行信息的传输与处理时,必须共同持有该密码 ...

  2. MD5&&DES加密解密帮助类

    public class _MD5_NETCore加密解密 { /// <summary> /// 加密 /// </summary> /// <param name=& ...

  3. C#获取CPU与网卡硬盘序列号及Base64和DES加密解密操作类

    public class RegisterHelp { /// <summary> /// CPU /// </summary> /// <returns>< ...

  4. 【DES加密解密】 C#&JAVA通用

    DES加密解密 C# Code /// <summary> /// DES加密解密帮助类 /// </summary> public static class DESHelpe ...

  5. 一个java的DES加密解密类转换成C#

    一个java的des加密解密代码如下: //package com.visionsky.util; import java.security.*; //import java.util.regex.P ...

  6. DES加密解密

    加密后生成Base64字符串,并去除'='字符. 加密后替换掉'+',这样加密后的字符串可以作为url参数传递. using System; using System.IO; using System ...

  7. C# MD5加密解密帮助类

    /// <summary>    /// MD5加密解密帮助类    /// </summary>    public static class DESHelper    {  ...

  8. 各种加密解密函数(URL加密解密、sha1加密解密、des加密解密)

    原文:各种加密解密函数(URL加密解密.sha1加密解密.des加密解密) 普通hash函数如md5.sha1.base64等都是不可逆函数.虽然我们利用php可以利用这些函数写出可逆函数来.但是跨语 ...

  9. DES加密解密与AES加密解密

    随着开发时间的变长,当初认为比较难的东西,现在渐渐也就变的不那么难了!特别对于一些经常很少使用的类,时间长了之后渐渐就陌生了.所以在这里写一些日后可能会用到的加密与解密. 一.AES加密算法和DES加 ...

随机推荐

  1. iOS开发必看的博客汇总

    OneV's Den http://onevcat.com/ 沉船家园 http://beyondvincent.com/ NSHipster http://nshipster.cn/ Limboy ...

  2. 编程算法 - 阅读完整的文件(C++)

    阅读完整的文件(C++) 本文地址: http://blog.csdn.net/caroline_wendy C++: 把文本文件(txt)的全部内容读入字符串(string), 最高效的方法. 代码 ...

  3. POJ 3013 Big Christmas Tree(最短Dijkstra+优先级队列优化,SPFA)

    POJ 3013 Big Christmas Tree(最短路Dijkstra+优先队列优化,SPFA) ACM 题目地址:POJ 3013 题意:  圣诞树是由n个节点和e个边构成的,点编号1-n. ...

  4. uva 12003 Array Transformer (大规模阵列)

    白皮书393页面. 乱搞了原始数组中.其实用另一种阵列块记录. 你不能改变原始数组. 请注意,与原来的阵列和阵列块的良好关系,稍微细心处理边境.这是不难. #include <cstdio> ...

  5. Cassandra C++/NodeJs开发环境

    工作的需要,开始更多地倾向于去中心化的结构,目前看来Cassandra算是去中心化DB中性能/管理最热门的选择,崇尚其P2P的理念. 自身原因对JAVA不擅长(周围写C的好少),还是更热衷于C++/J ...

  6. Hadoop群集设置

    Hadoop群集设置 近期特别看了Hadoop的资料.感觉特别好,整理一下发在自己的博客上,希望对想了解集群的网友有所帮助. 參考资料:http://hadoop.apache.org/docs/r1 ...

  7. Asp.Net MVC5入门学习系列①

    原文:Asp.Net MVC5入门学习系列① 现在直接开始MVC5的学习系列,学习资源来自Micrsoft. 开始使用Asp.Net MVC 5 打开Visual Studio 2013,然后新建一个 ...

  8. 微信应用号开发知识贮备之Webpack实战

    天地会珠海分舵注:随着微信应用号的呼之欲出,相信新一轮的APP变革即将发生.作为行业内人士,我们很应该去拥抱这个趋势.这段时间在忙完工作之余准备储备一下这方面的知识点,以免将来被微信应用号的浪潮所淹没 ...

  9. c语言中逗号运算符和逗号表达式

    原文:c语言中逗号运算符和逗号表达式 C语言提供一种特殊的运算符——逗号运算符.用它将两个表达式连接起来.如: 3+5,6+8称为逗号表达式,又称为“顺序求值运算符”.逗号表达式的一般形式为 表达式1 ...

  10. 使用Dropbox+Justwriting+Markdown建立个人博客

    使用Dropbox+Justwriting+Markdown建立个人博客,让您真正体会到什么是"简化". 您的博客所有日志存储在您的PC上.即使有一天你的server主机挂了,你的 ...