【发布时间】:2013-02-21 23:10:38
【问题描述】:
我过去只与log4j 合作过。现在我正在寻找一个新项目,并注意到它使用了slf4j 1.7.2。我知道它只是一个 API 规范,它为符合它的各种实现提供简化的接口(AKA 外观),例如java.util.logging, log4j and logback。但是,我注意到 API 网站的列表中没有提到 commons-logging,但是,它的 jar 在这个应用程序的类路径中。当我从类路径中删除它以检查它是否是使用的实现时,我确认它确实是:
SLF4J: Failed to load class "org.slf4j.impl.StaticLoggerBinder".
SLF4J: Defaulting to no-operation (NOP) logger implementation
SLF4J: See http://www.slf4j.org/codes.html#StaticLoggerBinder for further details.
Exception in thread "main" java.lang.NoClassDefFoundError: org/apache/commons/logging/LogFactory
commons-logging 确实是 slf4j 的默认实现吗?因为他们的文档说:
如果在类路径上没有找到绑定,那么 SLF4J 将默认为无操作实现。
在上面的链接页面。即使我在类路径中有slf4j-nop-1.7.2.jar,我猜上面提到的默认实现是,如果公共不在类路径中,我仍然会收到异常要求org/apache/commons/logging/LogFactory,所以我很困惑。
我们将不胜感激。
【问题讨论】:
-
我的猜测是您拥有的其他一些依赖项正在拉入公共日志记录。如果您使用 maven 或类似的构建工具,您应该能够可视化您的依赖关系树并查看包含 commons-logging 的内容。
-
其实我用的是Ant
标签: java logging slf4j apache-commons-logging