Java.io.ioexception: запрос на написание байтов превышает размер в заголовке байтов для входа. Сделайте более надежныеJAVA

Программисты JAVA общаются здесь
Ответить
Anonymous
 Java.io.ioexception: запрос на написание байтов превышает размер в заголовке байтов для входа. Сделайте более надежные

Сообщение Anonymous »

Я пытаюсь превратить молнию в смолу. Для этого я использую посетителя , но иногда, когда я делаю конверсию, у меня есть:
Caused by: platform.kernel.io.compresser.CompresserException:
at platform.kernel.io.compresser.TarIdefixCompresser.compress(TarIdefixCompresser.java:69)
at platform.kernel.io.compresser.IdefixCompresser.compress(IdefixCompresser.java:165)
at telegestion.daemon.sadmin.distribution.NodeFilesConsumer.sendFile(NodeFilesConsumer.java:351)
... 9 more
Caused by: java.io.IOException: request to write '69013' bytes exceeds size in header of '198041' bytes for entry 'CAT_ST_20250108-215416738.zip'
at org.apache.commons.compress.archivers.tar.TarArchiveOutputStream.write(TarArchiveOutputStream.java:377)
at platform.kernel.io.compresser.TarVisitor.visitFile(TarVisitor.java:55)
at platform.kernel.io.compresser.TarVisitor.visitFile(TarVisitor.java:27)
at java.nio.file.Files.walkFileTree(Unknown Source)
at java.nio.file.Files.walkFileTree(Unknown Source)
at platform.kernel.io.compresser.TarIdefixCompresser.compress(TarIdefixCompresser.java:66)
... 11 more
Suppressed: java.io.IOException: This archives contains unclosed entries.
at org.apache.commons.compress.archivers.tar.TarArchiveOutputStream.finish(TarArchiveOutputStream.java:220)
at org.apache.commons.compress.archivers.tar.TarArchiveOutputStream.close(TarArchiveOutputStream.java:236)
at platform.kernel.io.compresser.TarIdefixCompresser.compress(TarIdefixCompresser.java:68)
... 11 more

Метод визит file of tarvisitor class:
@Override
public FileVisitResult visitFile(Path pFile, BasicFileAttributes pAttrs) throws IOException {
try (FileInputStream lFis = new FileInputStream(pFile.toFile())) {
ArchiveEntry lArchiveEntry = tarOs.createArchiveEntry(pFile.toFile(),
pFile.getFileName().toString());
tarOs.putArchiveEntry(lArchiveEntry);
byte[] lBytesTampon = new byte[bufferSize];
int lCount;
while ((lCount = lFis.read(lBytesTampon)) != -1) {
tarOs.write(lBytesTampon, 0, lCount);
}
}
tarOs.closeArchiveEntry();
return FileVisitResult.CONTINUE;
}
< /code>
Я хотел бы знать, как я могу сделать свой метод более надежным и избежать этого типа проблемы.
Должен ли я сделать попытку для каждого исключения?
Я ожидаю, что мой zip-файл не очень хорошо закрыт после его создания, поэтому прямое преобразование в TAR может быть иногда не очень стабильным. ?@Override
public List compress(String pFileName, Path pParentPath, List pPathlist,
Integer pLevel, boolean pDeleteInputFiles) throws CompresserException {

String lFileName = pFileName + getExtension();
Path lPathCompressed = pParentPath.resolve(lFileName);
List lPathReturn = new ArrayList();
lPathReturn.add(lPathCompressed);
logCompression(lFileName, pPathlist);
try (ZipOutputStream lZipOs =
new ZipOutputStream(new FileOutputStream(lPathCompressed.toFile()))) {
lZipOs.setLevel(pLevel);
for (Path lPath : pPathlist) {
ZipVisitor lZipVisitor = new ZipVisitor(lZipOs, BUFFER_SIZE);
Files.walkFileTree(lPath, lZipVisitor);
}
} catch (IOException lEx) {
throw new CompresserException(IdefixComponentName.NONE,
KernelError.COMPRESSION_ERROR, lEx, "ZIP");
}
return lPathReturn;
}


Подробнее здесь: https://stackoverflow.com/questions/797 ... -bytes-for
Ответить

Быстрый ответ

Изменение регистра текста: 
Смайлики
:) :( :oops: :roll: :wink: :muza: :clever: :sorry: :angel: :read: *x)
Ещё смайлики…
   
К этому ответу прикреплено по крайней мере одно вложение.

Если вы не хотите добавлять вложения, оставьте поля пустыми.

Максимально разрешённый размер вложения: 15 МБ.

Вернуться в «JAVA»