我知道SLF4J存在一个常见问题:类路径包含多个SLF4J绑定。
SLF4J: Found binding in [jar:file:/C:/Users/<name>/.gradle/caches/4.9/generated-gradle-jars/gradle-api-4.9.jar!/org/slf4j/impl/StaticLoggerBinder.class]
SLF4J: Found binding in [jar:file:/C:/Users/<name>/.gradle/caches/modules-2/files-2.1/org.apache.logging.log4j/log4j-slf4j-impl/2.2/afd596adf5086b4f4746254b25a3a4b513f1d6e4/log4j-slf4j-impl-2.2.jar!/org/slf4j/impl/StaticLoggerBinder.class]
我在运行gradle构建并且应用了gradle-plugin插件时遇到此错误 例如
类import org.gradle.api.*
class CommonTestPlugin implements Plugin<Project> {
并在gradle中
apply plugin: 'java-gradle-plugin'
我正在使用该插件,因此我可以添加代码来创建插件。
上面的错误似乎指向gradle-api作为有问题的依赖关系,但是当我用以下命令启动依赖关系见解任务时 dependencyInsight --dependency gradle-api
它返回:
No dependencies matching given input were found in configuration ':compileClasspath'
我的问题是:我如何确定如何定义/排除插件正在使用的依赖关系?我正在使用类似以下的内容,我只是想不出如何将其应用于plugin-api
compile (group: 'com.aestasit.infrastructure.sshoogr', name: 'sshoogr', version: '0.9.26'){
// exclude this to stop warnings about multiple SLF4J bindings.
exclude group: 'ch.qos.logback', module: 'logback-classic'
}
答案 0 :(得分:0)
我遇到了同样的问题。到目前为止,我发现的解决方法是将要构建的目标JAR残酷地排除在外:
bootJar{
exclude('gradle-api-*.jar', 'groovy-*.jar')
}
我正在使用Spring boot插件。 bootJar
扩展了jar
任务。
尽管如此,问题仍然存在:插件的所有用户是否都必须进行这种排除,才能使其正常工作?