小编Cap*_*bol的帖子

将一个非常大的二进制文件逐步转换为Base64String

我需要帮助将非常大的二进制文件(ZIP文件)转换为Base64String并再次返回.这些文件太大而无法一次性加载到内存中(它们会抛出OutOfMemoryExceptions),否则这将是一项简单的任务.我不想单独处理ZIP文件的内容,我想处理整个ZIP文件.

问题:

我可以将整个ZIP文件(测试大小从1 MB到目前的800 MB)转换为Base64String,但是当我将其转换回来时,它已被破坏.新的ZIP文件大小正确,它被Windows和WinRAR/7-Zip等识别为ZIP文件,我甚至可以查看ZIP文件内部并查看具有正确尺寸/属性的内容,但是当我试图从ZIP文件中提取,我得到:"错误:0x80004005"这是一般错误代码.

我不确定腐败发生的地点或原因.我做了一些调查,我注意到以下几点:

如果您有一个大文本文件,您可以逐步将其转换为Base64String而不会出现问题.如果调用Convert.ToBase64String整个文件产生:"abcdefghijklmnopqrstuvwx",那么在文件中分两部分调用它将产生:"abcdefghijkl""mnopqrstuvwx".

不幸的是,如果文件是二进制文件,那么结果就不同了.虽然整个文件可能会产生:"abcdefghijklmnopqrstuvwx",尝试将其分为两部分会产生类似:"oiweh87yakgb""kyckshfguywp".

有没有办法逐步基础64编码二进制文件,同时避免这种损坏?

我的代码:

        private void ConvertLargeFile()
        {
           FileStream inputStream  = new FileStream("C:\\Users\\test\\Desktop\\my.zip", FileMode.Open, FileAccess.Read);
           byte[] buffer = new byte[MultipleOfThree];
           int bytesRead = inputStream.Read(buffer, 0, buffer.Length);
           while(bytesRead > 0)
           {
              byte[] secondaryBuffer = new byte[buffer.Length];
              int secondaryBufferBytesRead = bytesRead;
              Array.Copy(buffer, secondaryBuffer, buffer.Length);
              bool isFinalChunk = false;
              Array.Clear(buffer, 0, buffer.Length);
              bytesRead = inputStream.Read(buffer, 0, buffer.Length);
              if(bytesRead == …
Run Code Online (Sandbox Code Playgroud)

c# base64 zipfile

9
推荐指数
2
解决办法
5934
查看次数

标签 统计

base64 ×1

c# ×1

zipfile ×1