java我不能在没有slf4j的情况下使用log4j吗?
我试图将log4j
用于一个简单、小型的maven应用程序,它作为一个JAR运行。我知道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
东西时会抛出错误
我尝试过在我的pom.xml
中添加各种slf4j
依赖项,但没有任何帮助,也无助于我理解实际问题
有没有一种方法可以直接使用log4j
而不出现任何错误?如果没有,如何消除这个错误
# 1 楼答案
检查你的依赖树
找出哪个依赖项具有可传递的slf4j依赖项。我怀疑它是commons httpclient,因为它只有以下依赖项(并使用commons日志记录):
最后,您必须找出使用的是哪个slf4j api版本(请使用
mvn dependency:resolve
进行检查),并提供匹配的log4j绑定库(请参见SLF4J Manual)