如何为简单的maven应用程序配置slf4j以正确显示日志?

时间:2013-12-24 14:57:55

标签: java tomcat7 slf4j

我有简单的网络应用程序(src is here)。我尝试配置记录器。我有 logback.xml 文件,如下所示:

<?xml version="1.0" encoding="UTF-8"?>

<configuration>
  <appender name="STDOUT" class="ch.qos.logback.core.ConsoleAppender">
    <!-- encoders are assigned the type ch.qos.logback.classic.encoder.PatternLayoutEncoder by default -->
    <encoder>
      <pattern>%d{HH:mm:ss.SSS} [%thread] %-5level %logger{5} - %msg%n</pattern>
    </encoder>
  </appender>
  <root level="DEBUG">
    <appender-ref ref="STDOUT" />
  </root>
</configuration>

pom.xml 依赖项:

<dependency>
  <groupId>org.slf4j</groupId>
  <artifactId>slf4j-api</artifactId>
  <version>1.7.5</version>
</dependency>

<dependency>
  <groupId>org.slf4j</groupId>
  <artifactId>jcl-over-slf4j</artifactId>
  <version>1.7.5</version>
  <scope>runtime</scope>
</dependency>

<dependency>
  <groupId>org.slf4j</groupId>
  <artifactId>log4j-over-slf4j</artifactId>
  <version>1.7.5</version>
</dependency>

<dependency>
  <groupId>org.slf4j</groupId>
  <artifactId>slf4j-nop</artifactId>
  <version>1.7.5</version>
</dependency>

Index.java 控制器中,测试是:

LOG.info("LOG Info - Index called!");
LOG.warn("LOG Warn -Index called!");
LOG.trace("LOG Trace -Index called!");
LOG.error("LOG Error -Index called!");
LOG.debug("LOG Debug -Index called!");
System.out.println("System out -Index called!");

当我启动应用程序时: mvn tomcat7:运行并转到页面:控制台上的索引页面(/ simple-spring-mvc)仅显示:System out -Index called!

记录器看起来像:

private static final Logger LOG = LoggerFactory.getLogger(Index.class);

请解释我,如何正确配置或我做错了什么。

1 个答案:

答案 0 :(得分:1)

首先,如果您正在使用logback,则需要将其定义为maven依赖项:

<dependency>
    <groupId>ch.qos.logback</groupId>
    <artifactId>logback-classic</artifactId>
    <version>1.0.11</version>
</dependency>

然后,我注意到你正在定义slf4j-nop - 这是你问题的根本原因 - 你可以继续删除它。

希望这会有所帮助。