Spring AOP来自定义注解实现审计或日志记录

参考原文地址:https://blog.csdn.net/yang_lover/article/details/53037323

干货示例代码https://blog.csdn.net/songzehao/article/details/90490023

AOP切面补充:

一、@Before,@After,@Around,@AfterReturning,@AfterThrowing执行顺序:

@Around(ProceedingJoinPoint pjp)
    -》@Around(ProceedingJoinPoint pjp)-》pjp.proceed()开始执行真正的业务方法
    -》@Before(JoinPoint joinPoint)
    -》@Around(ProceedingJoinPoint pjp)-》pjp.proceed()结束执行真正的业务方法
    -》@After(JoinPoint joinPoint),不论该业务方法是否有异常
    -》@AfterReturning/@AfterThrowing

二、如何获取@AfterReturning的返回值:

// 可以重载afterReturning方法,不加returning参数即可
@AfterReturning(pointcut = "audit()", returning = "mv")
public void doAfterReturning(ModelAndView mv) {
    system.out.println(mv.getModel().containsKey("actionErrors"));
}

三、若加自定义注解中的一些方法没有返回值:   

// 可以重载afterReturning方法,不加returning参数即可
@AfterReturning(pointcut = "audit()")
public void doAfterReturning(JoinPoint joinPoint) {
}

    需要注意此时,无返回值的业务方法只会走无返回值的此重载方法,而带返回值的业务方法则会先进带返回值的afterReturning再走无返回值的afterReturning

 

你可能感兴趣的:(Spring,SpringAOP,审计功能,自定义注解)