spring aop调用joinPoint.proceed方法执行了两次的原因

通过DeBug模式追查问题和问了度娘之后,整理解决方法如下:

1、多余地使用了invoke调用方法

在方法中调用 joinPoint.proceed() 方法时,会执行两次。因为除开你在本方法中执行的一次之外,spring会在方法也会执行一次.所以应该改用@XXXReturning等方法,如@After改成@AfterReturning:

@AfterReturning(value = "execution(* *(..)) && @annotation(log)",returning = "result")// 指定拦截被LogAnnotation注解的方法
public void afterLog(JoinPoint point, LogAnnotation log,Object result) {}

Object result即是方法的运行结果

 

2、使用了多余的标签

比如,切面类的注解,如果包含@Component会导致执行两次:
@Aspect
@Order(0)
@Component

 

参考:https://zhidao.baidu.com/question/1735635628431003907.html

 

不过@Component如果作为自动装配bean的存在,去掉显然不合适(解决参考方法一)。

 

3、使用的是@Around方式

@Befor 方法前执行一次
@Around 方法前后各执行一次(相当于@Befor和@After一起使用)
@After 方法后执行一次

参考:https://bbs.csdn.net/topics/220027749

 

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值