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

本文涉及的产品
密钥管理服务KMS,1000个密钥,100个凭据,1个月
简介:

今天,看到网友咨询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如需转载请自行联系原作者

相关文章
用python对文件内容进行加密的2种方式
这篇文章介绍了使用Python对文件内容进行加密的两种方式:利用`cryptography`库的Fernet对称加密和使用`rsa`库进行RSA非对称加密。
117 6
2023/11/10学习记录-C/C++对称分组加密DES
本文介绍了对称分组加密的常见算法(如DES、3DES、AES和国密SM4)及其应用场景,包括文件和视频加密、比特币私钥加密、消息和配置项加密及SSL通信加密。文章还详细展示了如何使用异或实现一个简易的对称加密算法,并通过示例代码演示了DES算法在ECB和CBC模式下的加密和解密过程,以及如何封装DES实现CBC和ECB的PKCS7Padding分块填充。
59 4
2023/11/10学习记录-C/C++对称分组加密DES
DES加密初探
本文介绍了Python中常用的DES和3DES加解密方法,包括ECB和CBC模式。通过示例代码展示了如何使用`Crypto`和`pyDes`库实现加解密,并讨论了不同的填充方式。最后,通过一道CTF例题,详细解析了从图像中提取密文、进行ASCII转换、Base64解码、凯撒解码和最终的DES解密过程。
62 4
DES加密初探
|
25天前
|
C#
基于 C# 编写的 Visual Studio 文件编码显示与修改扩展插件
基于 C# 编写的 Visual Studio 文件编码显示与修改扩展插件
python知识点100篇系列(15)-加密python源代码为pyd文件
【10月更文挑战第5天】为了保护Python源码不被查看,可将其编译成二进制文件(Windows下为.pyd,Linux下为.so)。以Python3.8为例,通过Cython工具,先写好Python代码并加入`# cython: language_level=3`指令,安装easycython库后,使用`easycython *.py`命令编译源文件,最终生成.pyd文件供直接导入使用。
121 3
python知识点100篇系列(15)-加密python源代码为pyd文件
Zipfile学习笔记(二)::通过zipfile模块暴力破解加密的压缩文件
如何使用Python的zipfile模块生成密码表并尝试暴力破解加密的ZIP压缩文件。
65 1
Zipfile学习笔记(二)::通过zipfile模块暴力破解加密的压缩文件
Python实行任意文件的加密—解密
Python实行任意文件的加密—解密
32 2
Python实行任意文件的加密—解密
Python实行任意文件的加密—解密
60 1
|
3月前
|
C#使用哈夫曼编码实现压缩与解压
C#使用哈夫曼编码实现压缩与解压
49 0
AI助理

你好,我是AI助理

可以解答问题、推荐解决方案等