Maven类路径错误多个SLF4J绑定

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Maven类路径错误多个SLF4J绑定相关的知识,希望对你有一定的参考价值。

我在尝试进行MAVEN安装时遇到了这个错误。我尝试了排除,但不确定在pom文件中包含的位置。让我知道如何以及在我的pom文件中包含哪些排除标记。我还附加了我的pom文件片段,其中包含exclusions`SLF4J:类路径包含多个SLF4J绑定。

SLF4J:在[jar:file:/ C:/Users/147188/.m2/repository/ch/qos/logback/logback-classic/1.2.3/logback-classic-1.2.3.jar!/ org /中找到绑定SLF4J / IMPL / StaticLoggerBinder.class]

SLF4J:在[jar:file:/ C:/Users/147188/.m2/repository/org/apache/logging/log4j/log4j-slf4j-impl/2.10.0/log4j-slf4j-impl-2.10.0中找到绑定.JAR!/org/slf4j/impl/StaticLoggerBinder.class]

SLF4J:请参阅http://www.slf4j.org/codes.html#multiple_bindings以获得解释。 SLF4J:实际绑定的类型为[ch.qos.logback.classic.util.ContextSelectorStaticBinder]

POM文件:

<!-- Start of required part to make log4j work -->
<dependency>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-web</artifactId>
    <exclusions>
    <exclusion>
        <groupId>org.slf4j</groupId>
        <artifactId>slf4j-log4j12</artifactId>
    </exclusion>
</exclusions> 
</dependency>
<dependency>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter</artifactId>

    <exclusions>
    <exclusion>
        <groupId>org.slf4j</groupId>
        <artifactId>slf4j-log4j12</artifactId>
    </exclusion>
        <exclusion>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-logging</artifactId>
        </exclusion>
    </exclusions>
</dependency>
<dependency>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-log4j2</artifactId>
    <exclusions>
    <exclusion>
        <groupId>org.slf4j</groupId>
        <artifactId>slf4j-log4j12</artifactId>
    </exclusion>
</exclusions> 
</dependency>
        <!-- End of required part to make log4j work -->
答案

1运行

mvn dependency:tree

看哪个包导入org.slf4j

2保留一个,排除其他

   <exclusion>
        <groupId>org.slf4j</groupId>
        <artifactId>slf4j-log4j12</artifactId>
    </exclusion>
另一答案

该消息表明您引入了logback-classic和log4j-slf4j-impl,它们都希望成为SLF4J绑定的日志框架。如果您不确定哪个依赖项带来了哪些其他依赖项,我发现运行“mvn dependency:tree”以查看正在使用的依赖项树是非常有用的。这应该为您提供足够的信息,以确定您需要排除哪个日志框架绑定。

正如documentation that the warning points to you所说,

嵌入式组件(如库或框架)不应声明对任何SLF4J绑定的依赖性,而仅依赖于slf4j-api。当库声明对SLF4J绑定的编译时依赖性时,它会对最终用户强制绑定,从而否定SLF4J的用途。当您遇到一个嵌入式组件声明对任何SLF4J绑定的编译时依赖关系时,请花时间联系所述组件/库的作者,并请他们修改他们的方法。

您非常希望从所有依赖项中排除所有实际日志记录框架,以便使用的唯一日志框架是您明确添加的日志框架。我甚至经常发现设置一些maven-enforcer-plugin bannedDependencies规则是有用的,以确保我在更新我的依赖项时不会意外引入另一个日志框架。在POM中使用dependencyManagement部分也很有帮助,以确保所有依赖项都使用相同版本的slf4j-api。

以上是关于Maven类路径错误多个SLF4J绑定的主要内容,如果未能解决你的问题,请参考以下文章

SLF4J:类路径包含多个 SLF4J 绑定 slf4j-test vs logback-classic

类路径包含多个 SLF4J 绑定,即使有排除项

如何在 Play 2.3.x 启动时修复“SLF4J:类路径包含多个 SLF4J 绑定”?

多个 SLF4J 绑定 activemq-all-5.6.0.jar 出错

GWT,Gradle,多个SLF4J绑定错误

flume测试提示SLF4J绑定错误