当 SLF4J 位于 Maven pom.xml 文件中时,为什么会出现“No SLF4J”provider found 错误?

Ash*_* Xu 7 java log4j slf4j pom.xml maven

我目前在尝试运行 Spring Java 程序时遇到以下错误。

SLF4J: No SLF4J providers were found.
SLF4J: Defaulting to no-operation (NOP) logger implementation
SLF4J: See https://www.slf4j.org/codes.html#noProviders for further details.
SLF4J: Class path contains SLF4J bindings targeting slf4j-api versions 1.7.x or earlier.
SLF4J: Ignoring binding found at [jar:file:/C:/Users/user/.m2/repository/ch/qos/logback/logback-classic/1.2.11/logback-classic-1.2.11.jar!/org/slf4j/impl/StaticLoggerBinder.class]
SLF4J: Ignoring binding found at [jar:file:/C:/Users/user/.m2/repository/org/apache/logging/log4j/log4j-slf4j-impl/2.19.0/log4j-slf4j-impl-2.19.0.jar!/org/slf4j/impl/StaticLoggerBinder.class]
SLF4J: See https://www.slf4j.org/codes.html#ignoredBindings for an explanation.
Run Code Online (Sandbox Code Playgroud)

以下是 pom.xml 文件中具有 SLF4J 和 Log4J 依赖项的部分。该部分已在之前的项目中发挥过作用。

<dependency>
            <groupId>org.slf4j</groupId>
            <artifactId>slf4j-api</artifactId>
            <version>2.0.5</version>
        </dependency>
        <dependency>
            <groupId>org.apache.logging.log4j</groupId>
            <artifactId>log4j-slf4j-impl</artifactId>
            <version>2.19.0</version>
        </dependency>
        <dependency>
            <groupId>org.apache.logging.log4j</groupId>
            <artifactId>log4j-api</artifactId>
            <version>2.19.0</version>
        </dependency>
        <dependency>
            <groupId>org.apache.logging.log4j</groupId>
            <artifactId>log4j-core</artifactId>
            <version>2.19.0</version>
        </dependency>
Run Code Online (Sandbox Code Playgroud)

我没有任何针对 slf4j-api 版本 1..x 或更早版本的组件。这个错误信息似乎既表明我没有SLF4J,又表明我的版本错误。

如果有任何关于如何解决此问题的想法,我将不胜感激。谢谢你!

我尝试在 pom.xml 文件中使用不同的依赖项,但最终这些依赖项在以前的程序中有效。我还尝试查看可能也使用 SLF4J 的依赖项并从中排除 SLF4J,但我仍然收到错误消息。我已经尝试过其他类似问题的解决方案,但不断收到相同的错误。

man*_*uti 13

基于此文档

由于 SLF4J 绑定的兼容性中断,从版本 2.19.0 开始,提供了两个 SLF4J 到 Log4j 适配器。

  1. log4j-slf4j-impl应与 SLF4J 1.7.x 版本或更早版本一起使用。
  2. log4j-slf4j2-impl应与 SLF4J 2.0.x 版本或更高版本一起使用。

利用 Java 模块系统的应用程序应使用 SLF4J 2.0.x 和 log4j-slf4j2-impl。

因此,最简单的方法(如果您需要 SLF4J 2)是使用<artifactId>log4j-slf4j2-impl</artifactId>. 您可以做的另一件事是恢复到slf4j-api1.7.x。

其他注意事项:

  • SLF4J 日志显示它logback-classic也存在于依赖关系树中。您需要选择logback-classic或 log4j 绑定。运行mvn dependency:tree您的项目以查找logback-classic添加位置。

  • 如果你想保留logback-classic,那么和上面提到的一样,你需要使用logback-classic与SLF4J 2兼容的。