java.util.zip.ZipException:слишком много записей в ZIP-файле

StackOverflow https://stackoverflow.com/questions/483843

  •  20-08-2019
  •  | 
  •  

Вопрос

Я пытаюсь написать класс Java для извлечения большого zip-файла, содержащего ~ 74000 XML-файлов.Я получаю следующее исключение при попытке разархивировать его с помощью библиотеки Java zip:

java.util.zip.ZipException:слишком много записей в ZIP-файле

К сожалению, из-за требований проекта я не могу разобрать zip-архив до того, как он попадет ко мне, и процесс разархивирования должен быть автоматизирован (без ручных действий).Есть ли способ обойти это ограничение, используя java.util.zip или какую-либо стороннюю zip-библиотеку Java?

Спасибо.

Это было полезно?

Решение

С использованием ZipInputStream вместо ZipFile наверное, стоит это сделать.

Другие советы

Использование Apache IOUtils:

FileInputStream fin = new FileInputStream(zip);
ZipInputStream zin = new ZipInputStream(fin);
ZipEntry ze = null;

while ((ze = zin.getNextEntry()) != null) {
    FileOutputStream fout = new FileOutputStream(new File(
                    outputDirectory, ze.getName()));

    IOUtils.copy(zin, fout);

    IOUtils.closeQuietly(fout);
    zin.closeEntry();
}

IOUtils.closeQuietly(zin);

Стандарт Zip поддерживает максимум 65536 записей в файле.Если библиотека Java не поддерживает расширения ZIP64, она не будет работать должным образом, если вы попытаетесь прочитать или записать архив с 74 000 записей.

Я переработал метод, чтобы сделать работу со структурами каталогов более удобной и заархивировать сразу несколько целей.Обычные файлы будут добавлены в корень zip-файла. Если вы передадите каталог, базовая структура будет сохранена.

def zip (String zipFile, String [] filesToZip){ 
    def result = new ZipOutputStream(new FileOutputStream(zipFile))
    result.withStream { zipOutStream ->
        filesToZip.each {fileToZip ->
            ftz = new File(fileToZip)
            if(ftz.isDirectory()){
                pathlength = new File(ftz.absolutePath).parentFile.absolutePath.size()
                ftz.eachFileRecurse {f ->               
                    if(!f.isDirectory()) writeZipEntry(f, zipOutStream, f.absolutePath[pathlength..-1]) 
                }
            }               
            else writeZipEntry(ftz, zipOutStream, '')
        }
    }
}

def writeZipEntry(File plainFile, ZipOutputStream zipOutStream, String path) {
    zipOutStream.putNextEntry(new ZipEntry(path+plainFile.name))
    new FileInputStream(plainFile).withStream { inStream ->
        def buffer = new byte[1024]
        def count
        while((count = inStream.read(buffer, 0, 1024)) != -1) 
            zipOutStream.write(buffer)                  
    }
    zipOutStream.closeEntry()
}
Лицензировано под: CC-BY-SA с атрибуция
Не связан с StackOverflow
scroll top