在使用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 读取嵌入式存档文件的字节压缩?
最佳答案
你做了一些奇怪的事情stuff it seems? For each archieve entry while your reading your 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);
}
关于java - 该输入流是否已关闭?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/18065623/