日志记录

Spring自带一个在spring-jcl模块中实现的Commons Logging桥。该实现检查类路径中是否存在Log4j 2.x API和 SLF4J 1.7 API,并使用找到的第一个作为日志记录实现,如果Log4j 2.x和 SLF4J均不可用,则回退到Java平台的核心日志记录功能(也称为JULjava.util.logging)。

将Log4j 2.x或Logback(或其他 SLF4J提供程序)放入您的类路径中,无需任何额外的桥接,并让框架自动适应您的选择。有关更多信息,请参阅Spring Boot日志记录参考文档

Spring的Commons Logging变体仅用于核心框架和扩展中的基础结构日志记录目的。

对于应用程序代码中的日志记录需求,建议直接使用Log4j 2.x、 SLF4J或 JUL。

可以通过org.apache.commons.logging.LogFactory检索Log实现,如下例所示。

  • Java

  • Kotlin

public class MyBean {
	private final Log log = LogFactory.getLog(getClass());
    // ...
}
class MyBean {
  private val log = LogFactory.getLog(javaClass)
  // ...
}