C# DES 加密/解密类库,支持文件和中文/UNICODE字符,返回BASE64编码字符串

今天,看到网友咨询DES加密的事,就写了下面的类库,sharing 一下,欢迎多交流

复制代码
using  System;
using  System.Collections.Generic;
using  System.Text;
using  System.IO;
using  System.Security;
using  System.Security.Cryptography;

/* ----------------------------------------------
* DES加密、解密类库,字符串加密结果使用BASE64编码返回,支持文件的加密和解密
* 作者: 三角猫/DeltaCat
* 网址: 
http://www.zu14.cn
* 转载务必保留此信息
* ---------------------------------------------
*/

namespace  ZU14
{
public   sealed   class  DES
{
string  iv  =   " 1234的yzo " ;
string  key  =   " 123在yzo " ;

///   <summary>
///  DES加密偏移量,必须是>=8位长的字符串
///   </summary>
public   string  IV
{
get  {  return  iv; }
set  { iv  =  value; }
}

///   <summary>
///  DES加密的私钥,必须是8位长的字符串
///   </summary>
public   string  Key
{
get  {  return  key; }
set  { key  =  value; }
}

///   <summary>
///  对字符串进行DES加密
///   </summary>
///   <param name="sourceString"> 待加密的字符串 </param>
///   <returns> 加密后的BASE64编码的字符串 </returns>
public   string  Encrypt( string  sourceString)
{
byte [] btKey  =  Encoding.Default.GetBytes(key);
byte [] btIV  =  Encoding.Default.GetBytes(iv);
DESCryptoServiceProvider des 
=   new  DESCryptoServiceProvider();
using  (MemoryStream ms  =   new  MemoryStream())
{
byte [] inData  =  Encoding.Default.GetBytes(sourceString);
try
{
using  (CryptoStream cs  =   new  CryptoStream(ms, des.CreateEncryptor(btKey, btIV), CryptoStreamMode.Write))
{
cs.Write(inData, 
0 , inData.Length);
cs.FlushFinalBlock();
}

return  Convert.ToBase64String(ms.ToArray());
}
catch
{
throw ;
}
}
}

///   <summary>
///  对DES加密后的字符串进行解密
///   </summary>
///   <param name="encryptedString"> 待解密的字符串 </param>
///   <returns> 解密后的字符串 </returns>
public   string  Decrypt( string  encryptedString)
{
byte [] btKey  =  Encoding.Default.GetBytes(key);
byte [] btIV  =  Encoding.Default.GetBytes(iv);
DESCryptoServiceProvider des 
=   new  DESCryptoServiceProvider();

using  (MemoryStream ms  =   new  MemoryStream())
{
byte [] inData  =  Convert.FromBase64String(encryptedString);
try
{
using  (CryptoStream cs  =   new  CryptoStream(ms, des.CreateDecryptor(btKey, btIV), CryptoStreamMode.Write))
{
cs.Write(inData, 
0 , inData.Length);
cs.FlushFinalBlock();
}

return  Encoding.Default.GetString(ms.ToArray());
}
catch
{
throw ;
}
}
}

///   <summary>
///  对文件内容进行DES加密
///   </summary>
///   <param name="sourceFile"> 待加密的文件绝对路径 </param>
///   <param name="destFile"> 加密后的文件保存的绝对路径 </param>
public   void  EncryptFile( string  sourceFile,  string  destFile)
{
if  ( ! File.Exists(sourceFile))  throw   new  FileNotFoundException( " 指定的文件路径不存在! " , sourceFile);

byte [] btKey  =  Encoding.Default.GetBytes(key);
byte [] btIV  =  Encoding.Default.GetBytes(iv);
DESCryptoServiceProvider des 
=   new  DESCryptoServiceProvider();
byte [] btFile  =  File.ReadAllBytes(sourceFile);

using  (FileStream fs  =   new  FileStream(destFile, FileMode.Create, FileAccess.Write))
{
try
{
using  (CryptoStream cs  =   new  CryptoStream(fs, des.CreateEncryptor(btKey, btIV), CryptoStreamMode.Write))
{
cs.Write(btFile, 
0 , btFile.Length);
cs.FlushFinalBlock();
}
}
catch
{
throw ;
}
finally
{
fs.Close();
}
}
}

///   <summary>
///  对文件内容进行DES加密,加密后覆盖掉原来的文件
///   </summary>
///   <param name="sourceFile"> 待加密的文件的绝对路径 </param>
public   void  EncryptFile( string  sourceFile)
{
EncryptFile(sourceFile, sourceFile);
}

///   <summary>
///  对文件内容进行DES解密
///   </summary>
///   <param name="sourceFile"> 待解密的文件绝对路径 </param>
///   <param name="destFile"> 解密后的文件保存的绝对路径 </param>
public   void  DecryptFile( string  sourceFile,  string  destFile)
{
if  ( ! File.Exists(sourceFile))  throw   new  FileNotFoundException( " 指定的文件路径不存在! " , sourceFile);

byte [] btKey  =  Encoding.Default.GetBytes(key);
byte [] btIV  =  Encoding.Default.GetBytes(iv);
DESCryptoServiceProvider des 
=   new  DESCryptoServiceProvider();
byte [] btFile  =  File.ReadAllBytes(sourceFile);

using  (FileStream fs  =   new  FileStream(destFile, FileMode.Create, FileAccess.Write))
{
try
{
using  (CryptoStream cs  =   new  CryptoStream(fs, des.CreateDecryptor(btKey, btIV), CryptoStreamMode.Write))
{
cs.Write(btFile, 
0 , btFile.Length);
cs.FlushFinalBlock();
}
}
catch
{
throw ;
}
finally
{
fs.Close();
}
}
}

///   <summary>
///  对文件内容进行DES解密,加密后覆盖掉原来的文件
///   </summary>
///   <param name="sourceFile"> 待解密的文件的绝对路径 </param>
public   void  DecryptFile( string  sourceFile)
{
DecryptFile(sourceFile, sourceFile);
}
}
}
复制代码

使用的例子

复制代码
ZU14.DES des  =   new  ZU14.DES();
des.IV 
=   " abcd哈哈笑 " ;
des.Key 
=   " 必须八位 " ;

string  es  =  des.Encrypt( " " );
Console.WriteLine(es);
Console.Write(des.Decrypt(es));

des.EncryptFile(
@" d:\a.txt " @" d:\b.txt " );
des.DecryptFile(
@" d:\b.txt " );

Console.ReadKey(
true );
复制代码

OK了。




本文转自黄聪博客园博客,原文链接:http://www.cnblogs.com/huangcong/archive/2010/03/26/1697230.html如需转载请自行联系原作者

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值