0

使用读取嵌入式存档文件时遇到一些非常奇怪的错误org.apache.commons.compress,我怀疑是我的经验不足困扰着我。

运行我的代码时,我收到各种截断的 zip 文件错误(以及其他截断的文件错误)。我怀疑这是我使用的ArchiveInputStream

private final void handleArchive(String fileName, ArchiveInputStream ais) {
   ArchiveEntry archiveEntry = null;

   try {
      while((archiveEntry = ais.getNextEntry()) != null) {

         byte[] buffer = new byte[1024];

         while(ais.read(buffer) != -1) {
            handleFile(fileName + "/" + archiveEntry.getName(), archiveEntry.getSize(), new ByteArrayInputStream(buffer));
   } catch(IOException ioe) {
      ioe.printStackTrace();
   }
}

当我这样做时,这archiveEntry = ais.getNextEntry()是否有效地关闭了我的ais,并且有什么方法可以使用 commons compress 读取嵌入式存档文件的字节?

4

1 回答 1

1

你似乎在做一些奇怪的事情?对于每个档案条目,当您阅读档案时,您会递归地调用您的 read archieve 方法,这会导致在您的父代码仍在处理您之前的档案时打开下一个档案。

在处理压缩文件中的任何新存档条目之前,您应该完全循环通过您的存档条目。就像是

ArArchiveEntry entry = (ArArchiveEntry) arInput.getNextEntry();
byte[] content = new byte[entry.getSize()];
LOOP UNTIL entry.getSize() HAS BEEN READ {
    arInput.read(content, offset, content.length - offset);
}

apache网站上的示例所述

于 2013-08-05T19:12:25.953 回答