豆角茄子子

导航

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

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

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。

 

posted on 2018-05-02 21:27  豆角茄子子  阅读(251)  评论(0编辑  收藏  举报