使用DotNetZip从流中提取zip
public void ZipExtract(Stream inputStream, string outputDirectory)
{
using (ZipFile zip = ZipFile.Read(inputStream))
{
Directory.CreateDirectory(outputDirectory);
zip.ExtractSelectedEntries("name=*.jpg,*.jpeg,*.png,*.gif,*.bmp", " ", outputDirectory,
ExtractExistingFileAction.OverwriteSilently);
}
}
[HttpPost]
public ContentResult Uploadify(HttpPostedFileBase filedata)
{
var path = Server.MapPath(@"~/Files");
var filePath = Path.Combine(path, filedata.FileName);
if (filedata.FileName.EndsWith(".zip"))
{
ZipExtract(Request.InputStream,path);
}
filedata.SaveAs(filePath);
_db.Photos.Add(new Photo
{
Filename = filedata.FileName
});
_db.SaveChanges();
return new ContentResult{Content = "1"};
}
我尝试从流中读取zip存档并提取文件。在“using(ZipFile zip = ZipFile.Read(inputStream))”行中得到以下异常:ZipEntry :: ReadDirEntry():位置0x0000EE19处的错误签名(0xC618F879)
任何想法如何处理此异常?
没有找到相关结果
已邀请:
2 个回复
荆怖赡
我认为你正在做的是尝试阅读该消息,就好像它是一个zip文件。那不行。文件内容实际上嵌入了“......这里的更多东西......”部分。 为了解决这个问题,我建议你采取较小的步骤。 首先,让文件上传工作,将上传文件的内容保存到服务器上的文件系统文件中。然后,在服务器上,尝试将文件作为zipfile打开。如果它工作,那么你应该能够用ZipFile.Read()替换文件保存部分。如果您无法打开保存的文件,则表示您保存的文件不是zip文件。要么它不完整,要么更有可能包括无关的数据,比如HTTP标头。 如果您无法成功上传像zip文件这样的二进制文件,请先处理上传文本文件的工作。通过在文本编辑器中打开上载的内容,并检查它是否包含从客户端上载的文件的内容,您可以更轻松地验证服务器上文本文件的上载。完成此操作后,请转到二进制文件。然后,您可以使用DotNetZip读取流,转到完整的流式方法。一旦达到这一点,在将其作为zip文件读取之前,不需要将文件保存到文件系统,但是出于其他原因,您可能还是想保存它。 为了提供帮助,您可能希望使用调试HTTP代理Fiddler2。将它安装在浏览器计算机上,打开它,它将帮助您查看从浏览器发送到服务器上的ASPNET应用程序的消息。您将看到文件上载包含的内容仅仅是裸文件数据。
公藕