全称为Jakarta Commons Logging,是Apache提供的一个通用日志API。
它是为 "所有的Java日志实现"提供一个统一的接口,它自身也提供一个日志的实现,但是功能非常常弱(SimpleLog)。所以一般不会单独使用它。他允许开发人员使用不同的具体日志实现工具: Log4j, Jdk自带的日志(JUL)
JCL 有两个基本的抽象类:Log(基本记录器)和LogFactory(负责创建Log实例)。
- <dependency>
- <groupId>commons-logginggroupId>
- <artifactId>commons-loggingartifactId>
- <version>1.2version>
- dependency>
- public class JCLTest {
- @Test
- public void testQuick() throws Exception {
- // 获取log日志记录器对象
- Log log = LogFactory.getLog(JCLTest.class);
- // 日志记录的输出
- log.info("hello info");
- }
- }
我们为什么要使用日志门面:
1. 通过LogFactory动态加载Log实现类
2. 日志门面支持的日志实现数组
- private static final String[] classesToDiscover =
- new String[]{"org.apache.commons.logging.impl.Log4JLogger",
- "org.apache.commons.logging.impl.Jdk14Logger",
- "org.apache.commons.logging.impl.Jdk13LumberjackLogger",
- "org.apache.commons.logging.impl.SimpleLog"};
3. 获取具体的日志实现
- for(int i = 0; i < classesToDiscover.length && result == null; ++i) {
- result = this.createLogFromClass(classesToDiscover[i], logCategory,true);
- }