将zip文件解压缩到一个文件夹会引发一个条目“无效的条目大小(预期46284但得到46285字节)”

时间:2012-12-19 09:38:25

标签: java

当我尝试按照下面的代码将zip文件解压缩到一个文件夹时,其中一个条目(文本文件)收到错误为“无效的条目大小(预期46284但得到46285字节)”和我的提取正在突然停止。我的zip文件包含大约12个文本文件和20个TIF文件。它遇到了文本文件的问题,因为它进入Catch块而无法继续进行。 我只在使用Unix运行的Production Server中遇到此问题,其他服务器(Dev,Test,UAT)没有问题。 我们通过外部团队将zip压缩到服务器路径,然后我的代码开始提取zip文件。

    ...
    int BUFFER = 2048;
    java.io.BufferedOutputStream dest = null;
    String ZipExtractDir = "/y34/ToBeProcessed/";
    java.io.File MyDirectory = new java.io.File(ZipExtractDir);
    MyDirectory.mkdir();
    ZipFilePath = "/y34/work_ZipResults/Test.zip";

    // Creating fileinputstream for zip file
    java.io.FileInputStream fis = new java.io.FileInputStream(ZipFilePath);

    // Creating zipinputstream for using fileinputstream
    java.util.zip.ZipInputStream zis = new java.util.zip.ZipInputStream(new java.io.BufferedInputStream(fis));
    java.util.zip.ZipEntry entry;
    while ((entry = zis.getNextEntry()) != null)
    {
        int count;
        byte data[] = new byte[BUFFER];
        java.io.File f = new java.io.File(ZipExtractDir + "/" + entry.getName());

        // write the files to the directory created above
        java.io.FileOutputStream fos = new java.io.FileOutputStream(ZipExtractDir + "/" + entry.getName());
        dest = new java.io.BufferedOutputStream(fos, BUFFER);
        while ((count = zis.read(data, 0, BUFFER)) != -1)
        {
            dest.write(data, 0, count);
        }
        dest.flush();
        dest.close();
    }
    zis.close();
    zis.closeEntry();
}
catch (Exception Ex)
{
    System.Out.Println("Exception in \"ExtractZIPFiles\"---- " + Ex.getMessage());
}

2 个答案:

答案 0 :(得分:3)

我无法理解您遇到的问题,但这是我用来解压缩档案的方法:

public static void unzip(File zip, File extractTo) throws IOException {
    ZipFile archive = new ZipFile(zip);
    Enumeration<? extends ZipEntry> e = archive.entries();
    while (e.hasMoreElements()) {
        ZipEntry entry = e.nextElement();
        File file = new File(extractTo, entry.getName());
        if (entry.isDirectory()) {
            file.mkdirs();
        } else {
            if (!file.getParentFile().exists()) {
                file.getParentFile().mkdirs();
            }
            InputStream in = archive.getInputStream(entry);
            BufferedOutputStream out = new BufferedOutputStream(new FileOutputStream(file));
            IOUtils.copy(in, out);
            in.close();
            out.close();
        }
    }
}

通话:

File zip = new File("/path/to/my/file.zip");
File extractTo = new File("/path/to/my/destination/folder");
unzip(zip, extractTo);

我从未遇到过上述代码的任何问题,所以我希望这可以帮到你。

答案 1 :(得分:2)

我能想到以下原因:

  1. 文本文件的编码可能有问题。
  2. 需要以“二进制”模式读取/传输文件。
  3. 结尾\n\r\n
  4. 的行可能存在问题
  5. 该文件可能只是损坏了。尝试使用zip实用程序打开文件。