一般的带管理功能的项目都要有一个日志管理的模块,提供系统审查的功能,最近在SSM的框架下使用log4j写日志文件,实现每天保存一份日志文件。
1.log4j的组成
Logger:决定输出什么日志信息
Appender:指定日志信息输出到什么地方,可以是控制台、日志文件、某台网络设备
Layout:指定日志信息的输出格式
2.log4j的输出等级
Debug<Info<Warn<Error<Fatal
3.log4j使用教程
第一步:导入commons-logging-1.0.4.jar 和 log4j-1.2.15.jar
第二步:把log4j的配置文件 log4j.properties放在src目录下
第三步:修改配置文件达到自己想要的效果
### set log levels ###
log4j.rootLogger =stdout , D
### output to the console ###
log4j.appender.stdout = org.apache.log4j.ConsoleAppender
log4j.appender.stdout.Target = System.out
log4j.appender.stdout.layout = org.apache.log4j.PatternLayout
#log4j.appender.stdout.layout.ConversionPattern = %d{ABSOLUTE} %5p %c{ 1 }:%L - %m%n
log4j.appender.stdout.layout.ConversionPattern = %-d{yyyy-MM-dd HH:mm:ss} [%c]-[%p] %m%n
### Output to the log file ###
log4j.appender.D = org.apache.log4j.DailyRollingFileAppender
log4j.appender.D.File = ${emcass.root}/WEB-INF/logs/error.log //文件自动创建在logs文件夹下,名字为error.log
log4j.appender.D.Append = true
log4j.appender.D.Threshold = ERROR //输出日志级别为ERROR
log4j.appender.D.layout = org.apache.log4j.PatternLayout
log4j.appender.D.layout.ConversionPattern = %-d{yyyy-MM-dd HH:mm:ss} [ %t:%r ] - [ %p ] %m%n
第四步:在想要调用的地方声明log
private Logger log = Logger.getLogger("你的类名");
try{
....
}catch(Exception e){
e.printStackTrace();
log.error("这里是错误信息"+e.getMessage,e);
}