【发布时间】:2011-04-01 00:04:56
【问题描述】:
我正在构建一个小型 Java 应用程序并希望使用 logback 进行日志记录。
我的应用依赖于通过
进行日志记录的旧项目org.apache.commons | com.springsource.org.apache.commons.logging | 1.1.1
...所以我的计划是使用
org.slf4j | jcl-over-slf4j | 1.5.6
...将 JCL 日志重定向到
org.slf4j | slf4j-api | 1.6.0
...最终到
ch.qos.logback | logback-classic | 0.9.22
ch.qos.logback | logback-core | 0.9.22
所以我的应用程序可以通过其 slf4j API 通过 logback 登录,而旧库代码可以通过重定向登录到同一位置。
唉,这导致
java.lang.NoSuchMethodError: org.slf4j.spi.LocationAwareLogger.log(Lorg/slf4j/Marker;Ljava/lang/String;ILjava/lang/String;Ljava/lang/Throwable;)V
at org.apache.commons.logging.impl.SLF4JLocationAwareLog.info(SLF4JLocationAwareLog.java:141)
我已经在其中一些 jar 上尝试了更高和更低的版本号,并且还深入研究了 API 文档等......但我无法找到并解决问题。
请帮忙?
虽然 logback 被认为是“战略”日志框架,但我对最终使用的日志机制有一些余地。不过,我希望使用 logback 或 log4j,而且我肯定希望通过通用配置将旧项目的日志记录合并到“新”日志记录框架最终成为的任何内容中。
【问题讨论】:
标签: java compatibility apache-commons slf4j logback