C#中的多线程加密

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?)。如果我的问题的答案在那里,您能否提供一些示例代码来使我朝正确的方向前进?

再次感谢!

Mon*_*nza 0

您需要将 Stream.Seek 用于读取流。查看以下问题: StreamReader 并寻求 帮助您避免常见的陷阱。

请记住,您必须准确记住每个流的开始和停止位置(特别是加密的流长度),否则您将无法解密文件切片。

祝你好运!