using System;
using System.IO;
using System.Security.Cryptography;
namespace web
{
/// <summary>
/// 文件加密
/// </summary>
public class FileEncrypt
{
private DESCryptoServiceProvider dc;//访问数据标准 DES 的加密服务提供程序
private byte[] dcIV; //初始化向量
private byte[] dcKey; //密钥
private byte[] cipherBytes; //加密之后的信息
private int keySize = 64; //密钥长度
/// <summary>
/// 构造函数,实例化定义访问数据标准 DES 的加密服务提供程序
/// 实例化密钥长度
/// </summary>
public FileEncrypt()
{
dc = new DESCryptoServiceProvider();//实例化 DES 加密服务提供程序
dc.KeySize = keySize; //初始化密钥长度
}
/// <summary>
/// 对指定文件加密
/// </summary>
/// <param name="filename">需要加密的文件路径</param>
/// <returns>加密之后的文件路径</returns>
public void EncryptMessage( string oldFilename, string newFilename )
{
FileStream sourceFile = new FileStream( oldFilename, FileMode.OpenOrCreate, FileAccess.Read );
FileStream targetFile = new FileStream( newFilename, FileMode.CreateNew, FileAccess.Write );
//将需要加密的字符串转换为byte数组
byte[] plainBytes = new byte[sourceFile.Length];
sourceFile.Read( plainBytes, 0, (int)sourceFile.Length );
sourceFile.Close();
dc.GenerateKey();//生成随机密钥
dc.GenerateIV(); //生成随初始化向量
dcIV = dc.IV; //初始化初始化向量
dcKey = dc.Key; //初始化密钥
//用指定的密钥和初始化向量创建对数据加密标准 DES 加密器对象
ICryptoTransform sse = dc.CreateEncryptor();
//创建一个内存流
MemoryStream ms = new MemoryStream();
//创建将数据流连接到加密转换流
CryptoStream cs = new CryptoStream(ms, sse, CryptoStreamMode.Write);
try
{
//将需要加密的信息写入加密转换流,并将流中的当前位置提升写入的字节数
cs.Write(plainBytes, 0, plainBytes.Length);
//用缓冲区的当前状态更新基础数据源或存储库,随后清除缓冲区
cs.FlushFinalBlock();
//将内存流中的内容写入字节数组
cipherBytes = ms.ToArray();
}
catch (Exception e)
{
throw ( new Exception( e.Message ) );
}
finally
{
//关闭写入的流
ms.Close();
//关闭当前流并释放与之相关的所有资源
cs.Close();
}
//将加密之后的信息写入文件流
targetFile.Write( cipherBytes, 0, cipherBytes.Length );
targetFile.Close();
} // 方法 加密信息
}
}