#基于注解的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 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否则无法正常编译。