使用install4j打包的org.apache.tools.tar.*类时,如何处理Java中的GNU长文件名?

使用install4j打包的org.apache.tools.tar.*类时,如何处理Java中的GNU长文件名?,java,ant,installation,tar,install4j,Java,Ant,Installation,Tar,Install4j,我正在尝试向install4j添加一个运行脚本,用于处理mysql和tomcat等嵌入到我的安装程序中的tarball的解压缩和解压。我意识到我可以将这些tar作为ant构建过程的一部分进行分解,但至少有一个用例我不能这样做 我已经使用org.apache.tools.tar.TarEntry和TarInputStream类将下面的代码包含在我的运行脚本操作中。这是相当好的工作,与一个错误 使用此实现,长度超过99个字符的文件路径将被截断,生成的文件将分解到顶级目录中 我试图弄清楚这是我的实现中

我正在尝试向install4j添加一个运行脚本,用于处理mysql和tomcat等嵌入到我的安装程序中的tarball的解压缩和解压。我意识到我可以将这些tar作为ant构建过程的一部分进行分解,但至少有一个用例我不能这样做

我已经使用org.apache.tools.tar.TarEntry和TarInputStream类将下面的代码包含在我的运行脚本操作中。这是相当好的工作,与一个错误

使用此实现,长度超过99个字符的文件路径将被截断,生成的文件将分解到顶级目录中

我试图弄清楚这是我的实现中的一个bug还是apache工具类的一个问题。当tarEntry.getName()超过99个字符时,它似乎没有返回整个路径。有没有一种简单的方法可以解决这个问题,而不必重写TarInputStream的功能?Entry有一个isGNULongNameEntry方法,但我似乎无法找到一种可靠的方法来说明当返回true时将文件放在何处

有什么建议吗

import java.io.*;
import java.util.zip.*;
import org.apache.tools.tar.TarEntry;
import org.apache.tools.tar.TarInputStream;

String outputDirectory = "mysql";
File tgzFile = new File(context.getInstallationDirectory(), outputDirectory + File.separator + "mysql-5.5.17-linux2.6-i686.tar.gz");

// Create the Tar input stream.
FileInputStream fin = new FileInputStream(tgzFile);
GZIPInputStream gin = new GZIPInputStream(fin);
TarInputStream tin = new TarInputStream(gin);

// Create the destination directory.
File outputDir = new File(outputDirectory);
outputDir.mkdir();

// Extract files.
TarEntry tarEntry = tin.getNextEntry();
while (tarEntry != null) {
    File destPath = new File(context.getInstallationDirectory(), outputDirectory + File.separator + tarEntry.getName());

tarEntry.isGNULongNameEntry()

    if (tarEntry.isDirectory()) {
        destPath.mkdirs();
    } else {
        // If the parent directory of a file doesn't exist, create it.
        if (!destPath.getParentFile().exists())
            destPath.getParentFile().mkdirs();

        FileOutputStream fout = new FileOutputStream(destPath);
        tin.copyEntryContents(fout);
        fout.close();
    // Presserve the last modified date of the tar'd files.
        destPath.setLastModified(tarEntry.getModTime().getTime());
    }
    tarEntry = tin.getNextEntry();
}
tin.close();

return true;

请随意查看我为此建议的修补程序
它至少可以给您一些指针。

虽然apache tar库不处理POSIX tar文件中的长文件名,但您可以使用GNU tar创建tar文件。在这种情况下,长文件名不会有问题。

谢谢Peter,至少这有助于我了解“我不是唯一一个处理类似问题的人。哇,你刚才提交的。我很惊讶他们没有得到补丁。是的,问题是我无法控制我正在处理的tar文件,它们是由第三方分发的。我可以解开并重新启动它们,但这不是一个很好的解决办法。