这次的笔记是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 ,如图


Java logger 如何正确的打出异常的日志 java如何打印异常日志_log4j捕获异常


配置配好了,要在想捕获 异常打印到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 );
	}
}