这次的笔记是log4j的配置和在系统出现异常时捕获,配置老老实实配置就行, 但是捕获异常就要结合Spring AOP来处理了。上代码
我自己定义一个LogUtils.java,作用是在捕获exception后日志文件写在exception.log中
LogUtils.java
package com.u;
import org.apache.log4j.Logger;
public class LogUtils {
public static Logger INFO = Logger.getLogger("info");
public static Logger EXCEPTION = Logger.getLogger("exception");
}
log4j.properties 文件配置
# debug,console,file 意思分别是 等级:打印控制台:打印保存的文件,等级有 OFF>FATAL>ERROR>WARN>INFO>DEBUG>TRACE>ALL 从高到低,注意,如果你选择debug,那么只能打印debug及以上的等级的日志,其他的也是这样
log4j.rootLogger=debug,console,file
# 打印有5种ConsoleAppender(打印到控制台),FileAppender(打印到文件),
# DailyRollingFileAppender(打印到文件,但每天只有一个),RollingFileAppender(打印到文件,可以设置文件大小,超出范围就新那一个文件),WriterAppender(将日志信息以流格式发送到任意指定的地方)
log4j.appender.console=org.apache.log4j.ConsoleAppender
# 打印的格式,分别是HTMLLayout(HTML表格形式),PatternLayout(自定义,基本用这个),SimpleLayout(包含日志信息的级别和信息字符串),TTCCLayout(日志产生的时间、线程、类别等等信息),
log4j.appender.console.layout=org.apache.log4j.PatternLayout
# 自定义打印内容的格式 %d %p %F 这些什么意思在最下面,百度截取的
log4j.appender.console.layout.ConversionPattern=%d{MM-dd HH:mm:ss} %p %F:%L - %m%n
log4j.appender.file=org.apache.log4j.DailyRollingFileAppender
log4j.appender.file.layout=org.apache.log4j.PatternLayout
log4j.appender.file.layout.ConversionPattern=%d{MM-dd HH:mm:ss} %p %F:%L - %m%n
# 打印到哪个文件,${catalina.base}是指服务的目录
log4j.appender.file.File=${catalina.base}/logs/SSH/console/console.log
# 这里作用是:比如今天是26号,那么今天的日志文件全名是console.log,等到27号,会生成一个新的console.log,26号的console.log会改名成console.log_2017-08-26.log如此类推。。。
log4j.appender.file.DatePattern='_'yyyy-MM-dd'.log'
log4j.appender.file.encoding=UTF-8
# 这时有点不同,上面都是log4j.appender.xxx,而这里是log4j.logger.yyy,一个是log4j.appender一个是log4j.logger,这里的yyy是自己定义的,这定义了一个LogUtils.java里面有行代码 public static Logger EXCEPTION = Logger.getLogger("yyy");,
# 代码中的yyy对应的就是log4j.logger.yyy中的yyy,也是就是当我用yyy记录日志时,打印日志所用到的格式呀,内容呀,文件呀,都是按下面的配置来的
log4j.logger.exception=ALL,exception
log4j.appender.exception=org.apache.log4j.DailyRollingFileAppender
log4j.appender.exception.layout=org.apache.log4j.PatternLayout
log4j.appender.exception.layout.ConversionPattern=%d{MM-dd HH:mm:ss} %p %F:%L - %m%n
log4j.appender.exception.File=${catalina.base}/logs/SSH/exception/exception.log
log4j.appender.exception.DatePattern='_'yyyy-MM-dd'.log'
log4j.appender.exception.encoding=UTF-8
# %p: 输出日志信息优先级,即DEBUG,INFO,WARN,ERROR,FATAL,
# %d: 输出日志时间点的日期或时间,默认格式为ISO8601,也可以在其后指定格式,比如:%d{yyy MMM dd HH:mm:ss,SSS},输出类似:2002年10月18日 22:10:28,921
# %r: 输出自应用启动到输出该log信息耗费的毫秒数
# %c: 输出日志信息所属的类目,通常就是所在类的全名
# %t: 输出产生该日志事件的线程名
# %l: 输出日志事件的发生位置,相当于%C.%M(%F:%L)的组合,包括类目名、发生的线程,以及在代码中的行数。举例:Testlog4.main(TestLog4.java:10)
# %x: 输出和当前线程相关联的NDC(嵌套诊断环境),尤其用到像java servlets这样的多客户多线程的应用中。
# %%: 输出一个"%"字符
# %F: 输出日志消息产生时所在的文件名称
# %L: 输出代码中的行号
# %m: 输出代码中指定的消息,产生的日志具体信息
# %n: 输出一个回车换行符,Windows平台为"\r\n",Unix平台为"\n"输出日志信息换行
# %20c:指定输出category的名称,最小的宽度是20,如果category的名称小于20的话,默认的情况下右对齐。
# %-20c:指定输出category的名称,最小的宽度是20,如果category的名称小于20的话,"-"号指定左对齐。
# %.30c:指定输出category的名称,最大的宽度是30,如果category的名称大于30的话,就会将左边多出的字符截掉,但小于30的话也不会有空格。
# %20.30c:如果category的名称小于20就补空格,并且右对齐,如果其名称长于30字符,就从左边交远销出的字符截掉。
如果properties文件 输入中文出现转码问题,在eclipse中右键properties 文件,找到下面的Properties,点击,设置编码为UTF-8 ,如图
配置配好了,要在想捕获 异常打印到exception.log中,就要配置 Spring AOP了,开始配置。。。
找到:applicationContext.xml,打开 , 加上 <aop:aspectj-autoproxy/>
接着,创建一个AOP类,
AOPClass.java
package com.a;
import org.aspectj.lang.JoinPoint;
import org.aspectj.lang.annotation.AfterThrowing;
import org.aspectj.lang.annotation.Aspect;
import org.aspectj.lang.annotation.Pointcut;
import org.springframework.stereotype.Component;
import com.u.LogUtils;
@Component
@Aspect
public class AOPClass {
@Pointcut("execution(* com.s..*(..))")
// 一个切面
public void aspect(){}
/**
* 捕获异常后
* @param joinPoint
* @param th
*/
@AfterThrowing(pointcut="aspect()", throwing="th")
public void error(JoinPoint joinPoint, Throwable th){
Exception ex = (Exception) th;
LogUtils.EXCEPTION.info("方法:【"+joinPoint.getSignature().getName()+"】异常"+ex.getMessage());
ex.printStackTrace();
// System.out.println(ec instanceof NullPointerException );
}
}