java.util.zip.ZipException:存储的块长度无效

时间:2013-02-25 16:21:00

标签: java apache-commons-io apache-commons-compress

我正在尝试将ZipArchiveEntry读取为String。我有以下代码,我遇到了异常

我的代码如下

StringWriter writer = new StringWriter();
IOUtils.copy(zipFile.getInputStream(zipArchiveEntry),
              writer,
              org.apache.commons.io.Charsets.UTF_8);

我得到以下异常

java.util.zip.ZipException: invalid stored block lengths
at java.util.zip.InflaterInputStream.read(InflaterInputStream.java:147)
at sun.nio.cs.StreamDecoder.readBytes(StreamDecoder.java:264)
at sun.nio.cs.StreamDecoder.implRead(StreamDecoder.java:306)
at sun.nio.cs.StreamDecoder.read(StreamDecoder.java:158)
at java.io.InputStreamReader.read(InputStreamReader.java:167)
at java.io.Reader.read(Reader.java:123)
at org.apache.commons.io.IOUtils.copyLarge(IOUtils.java:2001)
at org.apache.commons.io.IOUtils.copyLarge(IOUtils.java:1980)
at org.apache.commons.io.IOUtils.copy(IOUtils.java:1957)
at org.apache.commons.io.IOUtils.copy(IOUtils.java:1907)

真的坚持了很久。请帮忙。

1 个答案:

答案 0 :(得分:1)

我有一个看似有效的ZIP的类似情况,但是使用Java读取它有困难。异常与您相似,但是具有不同的堆栈跟踪:

Caused by: java.util.zip.ZipException: invalid stored block lengths
at java.util.zip.InflaterInputStream.read(InflaterInputStream.java:164)
at java.util.zip.ZipInputStream.read(ZipInputStream.java:194)
at java.util.zip.ZipInputStream.closeEntry(ZipInputStream.java:140)
at java.util.zip.ZipInputStream.getNextEntry(ZipInputStream.java:118)
...

在我的情况下,“故障” ZIP是使用CentOS计算机上的Ansible“归档”模块创建的:

- name: Create a zip archive
  archive:
    path: /tmp/mydir/
    dest: /tmp/mydir.zip
    format: zip

解决方法是在创建ZIP时在“路径”的末尾添加一个星号:

- name: Create a zip archive
  archive:
    path: /tmp/mydir/*
    dest: /tmp/mydir.zip
    format: zip

两个ZIP的内容相同,但是ZIP中的文件/目录属性存在一些差异,这显然会导致Java问题。