基于注解的AOP日志切面配置

#基于注解的AOP日志切面配置

前言

日志是我们用来发现问题和解决问题的好帮手,在业务越来越繁杂的大中型应用中,引入日志切面可以使我们用最少量的代码,记录下我们所需要的日志。

实现Web层的日志切面

  • 使用@Aspect注解将一个java类定义为切面类
  • 使用@Pointcut定义一个切入点,可以是一个规则表达式,比如下例中某个package下的所有函数,也可以是一个注解等。
  • 根据需要在切入点不同位置的切入内容
  • 使用@Before在切入点开始处切入内容
  • 使用@After在切入点结尾处切入内容
  • 使用@AfterReturning在切入点return内容之后切入内容(可以用来对处理返回值做一些加工处理)
  • 使用@Around在切入点前后切入内容,并自己控制何时执行切入点自身的内容
  • 使用@AfterThrowing用来处理当切入内容部分抛出异常之后的处理逻辑
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
@Aspect//1
@Order(1)//2
@Component
@Slf4j//3
public class WebLogHeadAspect {
@Pointcut("execution(public * com.business.controller..*.*(..))") //4
public void webLog() {
}
@Before("webLog()")//5
public void doBefore(JoinPoint joinPoint) {
if (joinPoint.getArgs()[0] instanceof ExtendedServletRequestDataBinder) {
return;
}//7
ServletRequestAttributes attributes = (ServletRequestAttributes) RequestContextHolder
.getRequestAttributes();
HttpServletRequest request = attributes.getRequest();
log.info("URL: {}, Method: {}, params: {}", request.getRequestURL(),
request.getMethod(), Arrays.toString(joinPoint.getArgs()));
}
@AfterReturning(returning = "ret", pointcut = "webLog()") //6
public void doAfterReturning(Object ret) {
log.info("Result : {}", JsonUtil.objectToJson(ret));
}
}

如上述代码所示

1.注解将一个java类定义为切面类
2.表示该切面的加载顺序,在切入点前的操作,按order的值由小到大执行,在切入点后的操作,按order的值由大到小执行
3.基于lombok的统一日志配置标签 需引入 lombok 的相关配置.
4.定义一个切入点,为该 Package下的所有控制器。
5.在webLog()函数执行前,也就是在控制器controller 前先执行doBefore()函数中的内容。这里面记录了URL,请求方式和入参
6.统计回调方式,记录result值。


新增

  1. 过滤数据绑定时触发多次切面日志记录

日志打印如下:

1
2
3
4
5
6
2018-02-14 at 21:10:03 CST INFO org.thymeleaf.TemplateEngine 838 initialize - [THYMELEAF] TEMPLATE ENGINE INITIALIZED
2018-02-14 at 21:10:17 CST INFO com.business.config.WebLogHeadAspect 37 doBefore - URL: http://127.0.0.1:8080/, params [{}]
2018-02-14 at 21:10:17 CST INFO com.business.config.WebLogHeadAspect 42 doAfterReturning - Result : "index"
2018-02-14 at 21:10:33 CST INFO com.business.config.WebLogHeadAspect 37 doBefore - URL: http://127.0.0.1:8080/api/xcl, params []
2018-02-14 at 21:10:33 CST INFO com.business.config.WebLogHeadAspect 42 doAfterReturning - Result : "xcl"

文末记录一下别的东西, 当node.js升级时,需要重新安装hexo-cil否则无法正常编译。