Bri*_*ian 5 c# encryption multithreading
我不熟悉加密,正在使用以下方法加密文件:
private static void encryptFile(string filePath, byte[] password, byte[] salt)
{
Rfc2898DeriveBytes rdb = new Rfc2898DeriveBytes(password, salt, 1000);
AesManaged algorithm = new AesManaged();
byte[] rgbKey = rdb.GetBytes(algorithm.KeySize / 8);
byte[] rgbIV = rdb.GetBytes(algorithm.BlockSize / 8);
GCHandle keyHandle = GCHandle.Alloc(rgbKey, GCHandleType.Pinned);
GCHandle IVHandle = GCHandle.Alloc(rgbIV, GCHandleType.Pinned);
ICryptoTransform cryptoAlgorithm = algorithm.CreateEncryptor(rgbKey, rgbIV);
using (FileStream readStream = File.Open(filePath, FileMode.Open))
{
using (FileStream writeStream = new FileStream(filePath + ".enc", FileMode.Create, FileAccess.Write))
{
using (CryptoStream cryptoStream = new CryptoStream(writeStream, cryptoAlgorithm, CryptoStreamMode.Write))
{
while (readStream.Position < readStream.Length)
{
byte[] buffer = new byte[4096];
int amountRead = readStream.Read(buffer, 0, buffer.Length);
cryptoStream.Write(buffer, 0, amountRead);
}
cryptoStream.Flush();
}
}
}
UtilityMethods.destroyBytes(rgbKey);
UtilityMethods.destroyBytes(rgbIV);
keyHandle.Free();
IVHandle.Free();
}
Run Code Online (Sandbox Code Playgroud)
我想做的是多线程处理,以加快加密速度。使用单个线程,这花费了超过5分钟的时间来加密〜3GB的文件。我希望能够在1分钟内完成该加密(30秒以下的时间很棒,但我想我可能会继续进行)。
我相信答案是创建多个流(尽管我不确定),为每个流分配要加密的文件块,但是我不确定如何“拆分文件”为每个流分配块,或在每个部分通过分配给它的流之后“将文件放回一起”。有人可以指出我正确的方向吗?
非常感谢!
PS我已经看过(Rijndael算法和CryptoStream:是否可以加密/解密多线程?),但是我不明白答案(ECB,CBC?)。如果我的问题的答案在那里,您能否提供一些示例代码来使我朝正确的方向前进?
再次感谢!
您需要将 Stream.Seek 用于读取流。查看以下问题: StreamReader 并寻求 帮助您避免常见的陷阱。
请记住,您必须准确记住每个流的开始和停止位置(特别是加密的流长度),否则您将无法解密文件切片。
祝你好运!