5

关于如何从 fatJar 中排除单个文件有很多重复的答案。通常,该文件被排除在 META-INF 中,并且它们被排除是因为文件名冲突,或者因为它是从依赖项 libarar Jar 文件复制的签名,该签名对新创建的 Jar 文件无效。

maven 示例: 如何判断哪个签名的 jar 导致 maven-shade-plugin 失败?

gradle 示例: Removing Jar Signatures in Gradle Build

但是,这些解决方案仅单独删除了有问题的文件。

我们如何制作一个排除特定依赖库(而不是该库中的单个文件)的 fatJar?

例如,在问题36226033中,很容易排除从 BouncyCastle 复制过来的签名,但是有没有办法bcprov-jdk15on-*.jar完全排除依赖库,以便用户必须拥有可用的库才能执行生成的 fat Jar?

事实证明这不起作用:

task fatJar(type: Jar) {
    manifest {
        attributes 'Implementation-Title': 'Gradle Jar File Example',
                'Implementation-Version': version,
                'Main-Class': 'com.alphawallet.scripttool.Main'
    }
    baseName = project.name + '-all'
    from { configurations.compile.collect { it.isDirectory() ? it : zipTree(it) } }
    exclude('**/bcprov-jdk15on-1.62.jar')
    with jar
}

使用exclude('**/bcprov-jdk15on-1.62.jar'),该 jar 文件的内容仍会复制到生成的 fat jar 中。

谢谢。动机是将我的 Java 应用程序发送到提供自己的安全库 BouncyCastle 的系统(例如 Debian Linux),而不是嵌入该安全库的未签名副本。

4

1 回答 1

7

我不知道如何excludes工作includes,但我希望这些配置在类文件级别上工作,因为 jar 正在工作。

它不适用于罐子。

我会选择这个解决方案:

task fatJar(type: Jar) {
    manifest {
        attributes 'Implementation-Title': 'Gradle Jar File Example',
                'Implementation-Version': version,
                'Main-Class': 'com.alphawallet.scripttool.Main'
    }
    baseName = project.name + '-all'
    configurations.compile.findAll { file ->
        // file is of type java.io.File
        // when true, jar file is unziped and added 
        file.name != "bcprov-jdk15on-1.62.jar"
    }.sort { it.name }
            .collect { file ->
                logger.info("Including file: ${file.name}")
                file.isDirectory() ? file : zipTree(file)
            }
    with jar
}
于 2020-01-08T09:43:50.207 回答