如何为Tomcat设置Spring日志


问题内容

使用Spring MVC且没有Spring日志使调试变得很困难。我读过其他一些关于此问题的文章,似乎都没有帮助。
log4j.propertiessrc文件夹中。slf4j-api-1.5.11slf4j-log4j12-1.5.11slf4j-simple-1.5.11commons- logging-1.1.jarlog4j-1.2.16.jarjar在classpath。
Log4j的内容是:

log4j.rootLogger=INFO, console


# Console appender
log4j.appender.console=org.apache.log4j.ConsoleAppender
log4j.appender.console.layout=org.apache.log4j.PatternLayout
log4j.appender.console.layout.ConversionPattern=%d [%-15.15t] %-5p %-30.30c{1} - %m%n
log4j.throwableRenderer=org.apache.log4j.EnhancedThrowableRenderer

但是我在控制台中看不到任何Spring日志。

注意:使用Spring 3.1


问题答案:

删除commons-logging-1.1.jar并添加jcl-over- slf4j-1.5.11.jar,因为您需要所有日志记录调用以通过slf4j,然后由log4j处理。

另外,您将需要在log4j.properties中添加spring的记录器,如下所示。log4j.properties需要以结尾tomcat/webapps/<application>/WEB- INF/classes

#Spring Framework
log4j.logger.org.springframework=INFO
log4j.logger.org.springframework.oxm=INFO
log4j.logger.org.springframework.transaction=WARN

Maven依赖项需要包含类似于以下内容的条目(摘自“
使用SLF4J”部分)。
请注意的排除commons-logging和包含jcl-over-slf4j

<dependency>
  <groupId>org.springframework</groupId>
  <artifactId>spring-context</artifactId>
  <version>3.1.2.RELEASE</version>
  <scope>runtime</scope>
  <exclusions>
     <exclusion>
       <groupId>commons-logging</groupId>
       <artifactId>commons-logging</artifactId>
     </exclusion>
  </exclusions>
</dependency>
<dependency>
  <groupId>org.slf4j</groupId>
  <artifactId>jcl-over-slf4j</artifactId>
  <version>1.7.0</version>
  <scope>runtime</scope>
</dependency>
<dependency>
  <groupId>org.slf4j</groupId>
  <artifactId>slf4j-api</artifactId>
  <version>1.7.0</version>
  <scope>runtime</scope>
</dependency>
<dependency>
  <groupId>org.slf4j</groupId>
  <artifactId>slf4j-log4j12</artifactId>
  <version>1.7.0</version>
  <scope>runtime</scope>
</dependency>
<dependency>
  <groupId>log4j</groupId>
  <artifactId>log4j</artifactId>
  <version>1.2.14</version>
  <scope>runtime</scope>
</dependency>