java - 不使用slf4j就不能使用log4j吗?

标签 java maven logging log4j slf4j

我正在尝试将 log4j 用于作为 JAR 运行的简单小型 Maven 应用程序。我知道 slf4j 有很多好处,但我试图使其尽可能简单,而不求助于 System.out

我的 pom.xml 中有以下内容:

<dependency>
    <groupId>log4j</groupId>
    <artifactId>log4j</artifactId>
    <version>1.2.17</version>
</dependency>

它主要工作,它按照我的 log4j.properties 的指示记录到一个文件。但是...

...我在控制台中看到以下内容:

SLF4J: slf4j-api 1.6.x (or later) is incompatible with this binding.
SLF4J: Your binding is version 1.5.5 or earlier.
SLF4J: Upgrade your binding to version 1.6.x.
Exception in thread "main" java.lang.NoSuchMethodError: org.slf4j.impl.StaticLoggerBinder.getSingleton()Lorg/slf4j/impl/StaticLoggerBinder;
        at org.slf4j.LoggerFactory.bind(LoggerFactory.java:129)
        at org.slf4j.LoggerFactory.performInitialization(LoggerFactory.java:108)
        at org.slf4j.LoggerFactory.getILoggerFactory(LoggerFactory.java:302)
        at org.slf4j.LoggerFactory.getLogger(LoggerFactory.java:276)
        at org.apache.commons.logging.impl.SLF4JLogFactory.getInstance(SLF4JLogFactory.java:155)
        at org.apache.commons.logging.impl.SLF4JLogFactory.getInstance(SLF4JLogFactory.java:131)
        at org.apache.commons.logging.LogFactory.getLog(LogFactory.java:351)

这似乎可能来自以下依赖项:

   <dependency>
        <groupId>commons-httpclient</groupId>
        <artifactId>commons-httpclient</artifactId>
        <version>3.1</version>
    </dependency>

由于日志记录直接起作用,并且当遇到 commons-httpclient 内容时会抛出错误。

我尝试过将各种 slf4j 依赖项添加到我的 pom.xml 中,但没有任何帮助,也无助于我理解实际问题。

有没有办法只使用log4j而不出现任何错误?如果不是,如何消除这个错误?

最佳答案

检查你的依赖树

 mvn dependency:tree

找出哪个依赖项具有传递性 slf4j 依赖项。我怀疑它是 commons-httpclient,因为它只有以下依赖项(并使用 commons 日志记录):

[INFO] --- maven-dependency-plugin:2.10:tree (default-cli) @ log4j ---
[INFO] binding:log4j:jar:0.0.1-SNAPSHOT
[INFO] \- commons-httpclient:commons-httpclient:jar:3.1:compile
[INFO]    +- commons-logging:commons-logging:jar:1.0.4:compile
[INFO]    \- commons-codec:commons-codec:jar:1.2:compile

您最终必须找出使用的 slf4j-api 版本(使用 mvn dependency:resolve 检查)并提供匹配的 log4j 绑定(bind)库(请参阅 SLF4J Manual )。

    <dependency>
        <groupId>org.slf4j</groupId>
        <artifactId>slf4j-log4j12</artifactId>
        <version>x.x.x</version>
    </dependency>

关于java - 不使用slf4j就不能使用log4j吗?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/29300832/

相关文章:

java - TestNG 测试不使用 TestPropertySource 来注入(inject) @Value

python - python 日志记录处理程序中 setLevel 的意义是什么?

java - 以编程方式初始化 log4j2 的更好方法(二)

java - Log4j2 用零填充文件名

java - 简单的java正则表达式不起作用

java - 将套接字设置为 null 而不是在 Java 中使用 ".close()"是错误的

Java Stream API - 计算嵌套列表的项目

java - 如何让套接字仅接受来自本地主机的连接(在 Java 中)?

java - 将嵌入式 Glassfish 与 Maven 结合使用

maven - 从 jenkins/maven build 发布 SNAPSHOT 到 nexus