步骤:
1. 在Maven的pom.xml 文件中添加dependency如下
<!-- sl4j日志包 -->
<!-- slf4j-log4j12-版本号.jar 依赖以下两个包,也会自动添加进来
slf4j-api-版本号.jar
log4j-版本号.jar
例如:slf4j-log4j12-1.7.2.jar,就依赖slf4j-api-1.7.2.jar和log4j-1.2.17.jar这两个包
-->
<dependency>
<groupId>org.slf4j</groupId>
<artifactId>slf4j-log4j12</artifactId>
<version>1.7.2</version>
</dependency>
<!-- end -->
之后就会添加三个包
slf4j-log4j12-1.7.2.jar
slf4j-api-1.7.2.jar
log4j-1.2.17.jar
2、在项目的src目录下添加log4j.properties
下面的是本案例的log4j.properties:
#日志级别大小: DEBUG < INFO < WARN < ERROR < FATAL
#log4j.rootLogger 配置的是大于等于当前级别的日志信息的输出
#log4j.rootLogger 用法:(注意appenderName可以是一个或多个)
#log4j.rootLogger = 日志级别,appenderName1,appenderName2,....
#log4j.appender.appenderName1定义的是日志的输出方式,有两种:一种是命令行输出或者叫控制台输出,另一种是文件方式保存
# 1)控制台输出则应该配置为org.apache.log4j.PatternLayout
# 2)文本方式保存应该配置为org.apache.log4j.DailyRollingFileAppender
# 3)也可以自定义 Appender类
#log4j.appender.appenderName1.layout.ConversionPattern 定义的是日志内容格式
#log4j.appender.appenderName1.file 定义了该日志文件的文件名称
#log4j.appender.appenderName1.DatePattern 定义了日志文件重新生成的时间间隔,如果设置到天,则每天重新生成一个新的日志文件。
# 旧的日志文件则以新的文件名保存,文件名称 = log4j.appender.appenderName1.file + log4j.appender.appenderName1.DatePattern
#log4j.rootLogger = info,stdout,file
log4j.rootLogger = info,stdout
log4j.appender.stdout=org.apache.log4j.ConsoleAppender
log4j.appender.stdout.layout=org.apache.log4j.PatternLayout
log4j.appender.stdout.layout.ConversionPattern=[%p][%d{yyyy-MM-dd HH:mm:ss}][%C{1}:%L] - %m%n
#log4j.appender.file = org.apache.log4j.DailyRollingFileAppender
#log4j.appender.file.file=d\:\\log\\info(+).log
#log4j.appender.file.DatePattern= '.'yyyy-MM-dd
#log4j.appender.file.layout=org.apache.log4j.PatternLayout
#log4j.appender.file.layout.ConversionPattern=[%p][%d{yyyy-MM-dd HH:mm:ss}][%C{1}:%L] - %m%n
# log4j.logger 用法如下
# 1)log4j.logger.包名 = 日志级别 , appenderName1,appenderName2,....
# 定义该包名下的所有类的日志输出
# 2)log4j.logger.类全名含包名 = 日志级别 , appenderName1,appenderName2,....
# 定义指定类的日志输出
# 3) log4j.logger.日志对象Logger命名名称 = 日志级别 , appenderName1,appenderName2,....
# 定义了某命名名称的日志的 输出,如:
# log4j.logger.Log1 就是指定义通过 Logger.getLogger("Log1") 获取的日志对象的日志输出
log4j.logger.edu.mvcdemo.controller = debug,controller_logfile
log4j.appender.controller_logfile = org.apache.log4j.DailyRollingFileAppender
log4j.appender.controller_logfile.file=d\:\\log\\controller_logfile.log
log4j.appender.controller_logfile.DatePattern= '.'yyyy-MM-dd
log4j.appender.controller_logfile.layout=org.apache.log4j.PatternLayout
log4j.appender.controller_logfile.layout.ConversionPattern=[%p][%d{yyyy-MM-dd HH:mm:ss}][%C{1}:%L] - %m%n
3、demo测试
其实,使用不管是使用sl4j还是log4j,都会加载log4j.properties
下面就通过demo,测试下使用sl4j打印的日志是否也会加载log4j.properties配置文件
Test.java:
package edu.mvcdemo.controller;
import org.apache.log4j.Logger;
import org.slf4j.LoggerFactory;
/**
* @编写人: yh.zeng
* @编写时间:2017-7-18 下午9:50:18
* @文件描述: todo
*/
public class Test {
private static org.apache.log4j.Logger log4jLogger = Logger.getLogger(Test.class);
private static org.slf4j.Logger slf4jLogger = LoggerFactory.getLogger(Test.class);
public static void main(String args[]){
String message = "Hello World";
log4jLogger.info("use log4j, message:" + message);
slf4jLogger.info("use slf4j, message:{}", message);
}
}
Console控制台打印的信息:
[INFO][2017-07-18 21:59:11][Test:18] - use log4j, message:Hello World
[INFO][2017-07-18 21:59:11][Test:19] - use slf4j, message:Hello World
日志记录文件: