我不确定我在做什么错。抓取byte[]
(即emailAttachment.Body)并将其传递给方法ExtractZipFile,将其转换为MemoryStream
然后解压缩,并将其作为KeyValuePair
返回后,创建的文件然后使用FileStream
写入文件。
但是,当我打开新创建的文件时,打开它们时出错。它们无法打开。
下面是同一班
using Ionic.Zip;
var extractedFiles = ExtractZipFile(emailAttachment.Body);
foreach (KeyValuePair<string, MemoryStream> extractedFile in extractedFiles)
{
string FileName = extractedFile.Key;
using (FileStream file = new FileStream(CurrentFileSystem +
FileName.FileFullPath(),FileMode.Create, System.IO.FileAccess.Write))
{
byte[] bytes = new byte[extractedFile.Value.Length];
extractedFile.Value.Read(bytes, 0, (int) xtractedFile.Value.Length);
file.Write(bytes,0,bytes.Length);
extractedFile.Value.Close();
}
}
private Dictionary<string, MemoryStream> ExtractZipFile(byte[] messagePart)
{
Dictionary<string, MemoryStream> result = new Dictionary<string,MemoryStream>();
MemoryStream data = new MemoryStream(messagePart);
using (ZipFile zip = ZipFile.Read(data))
{
foreach (ZipEntry ent in zip)
{
MemoryStream memoryStream = new MemoryStream();
ent.Extract(memoryStream);
result.Add(ent.FileName,memoryStream);
}
}
return result;
}
我缺少什么吗?我不想保存原始的zip文件,而只是保存从MemoryStream
中提取的文件。
我在做什么错了?
答案 0 :(得分:1)
写入MemoryStream后,您无需将位置重新设置为0:
MemoryStream memoryStream = new MemoryStream();
ent.Extract(memoryStream);
result.Add(ent.FileName,memoryStream);
因此,当您尝试从中读取流时,流的位置将位于末尾,而您将一无所获。确保快退:
memoryStream.Position = 0;
此外,您不必手动处理副本。只需让CopyTo
方法来处理它即可:
extractedFile.Value.CopyTo(file);
答案 1 :(得分:1)
我建议您清理代码中对MemoryStream
的使用。
我同意调用memoryStream.Position = 0;
可以使此代码正常工作,但是在读取和写入内存流时很容易错过。
编写避免该错误的代码更好。
尝试一下:
private IEnumerable<(string Path, byte[] Content)> ExtractZipFile(byte[] messagePart)
{
using (var data = new MemoryStream(messagePart))
{
using (var zipFile = ZipFile.Read(data))
{
foreach (var zipEntry in zipFile)
{
using (var memoryStream = new MemoryStream())
{
zipEntry.Extract(memoryStream);
yield return (Path: zipEntry.FileName, Content: memoryStream.ToArray());
}
}
}
}
}
然后您的调用代码将如下所示:
foreach (var extractedFile in ExtractZipFile(emailAttachment.Body))
{
File.WriteAllBytes(Path.Combine(CurrentFileSystem, extractedFile.Path.FileFullPath()), extractedFile.Content);
}
只需要更少的代码,就可以更好地避免错误。代码错误的第一预测因素是您编写的代码行数。
答案 2 :(得分:1)
因为我找到了所有用于简单操作的代码,所以这里是我的两分钱。
using Ionic.Zip;
using (var s = new MemoryStream(emailAttachment.Body))
using (ZipFile zip = ZipFile.Read(s))
{
foreach (ZipEntry ent in zip)
{
string path = Path.Combine(CurrentFileSystem, ent.FileName.FileFullPath())
using (FileStream file = new FileStream(path, FileAccess.Write))
{
ent.Extract(file);
}
}
}