我在将数据从MemoryStream复制到ZipArchive中的Stream时遇到了问题.以下不起作用 – 它只返回114个字节:
GetDataAsByteArray(IDataSource dataSource) { using (var zipStream = new MemoryStream()) { using (var archive = new ZipArchive(zipStream,ZipArchiveMode.Create,true)) { var file = archive.CreateEntry("compressed.file"); using (var targetStream = file.Open()) { using (var sourceStream = new MemoryStream()) { await dataSource.LoadIntoStream(sourceStream); sourceStream.CopyTo(targetStream); } } } var result = zipStream.ToArray(); zipStream.Close(); return result; } }
但是,使用下面的实现“copy”-process,所有1103个字节都写入数组/内存流:
await targetStream.WriteAsync(sourceStream.ToArray(),(int) sourceStream.Length);
我想知道为什么CopyTo产生更少的字节.在第二个实现中,我对Int32的强制转换感到不安全.
仅供参考:比较字节数组:看起来只有zip文件的页眉和页脚是由第一个实现编写的.
解决方法
Stream.CopyTo()从流的当前位置开始复制.在LoadIntoStream()调用之后可能不是0.由于它是一个MemoryStream,你可以简单地修复它:
await dataSource.LoadIntoStream(sourceStream); sourceStream.Position = 0; sourceStream.CopyTo(targetStream);