求助帖[AfterReturningAdvice的拦截方法执行混乱]

目标类及方法:
public interface AopService {
void helloword(String name);
}
public class AopServiceImpl implements AopService {
@Override
public void helloword(String name) {
System.out.println("helloword " + name);
}
}
方法成功后拦截器:
public class AfterReturning implements AfterReturningAdvice
{
@Override
public void afterReturning(Object returnValue, Method method, Object[] args, Object target) throws Throwable {
System.out.println(“这是返回方法:当前正在执行” + method.getName() + returnValue + args + target);
}
}
配置文件:

<bean id="proxyFactoryBean" class="org.springframework.aop.framework.ProxyFactoryBean">
    <!-- 目标对象,需要拦截的对象 -->
    <property name="target" ref="aopService"></property>
    <!-- 代理的接口 -->
    <property name="proxyInterfaces" value="com.example.demo.service.AopService"></property>
    <!-- 拦截器 -->
    <property name="interceptorNames" value="afterReturning"></property>
</bean>

<bean id="afterReturning" class="com.example.demo.aop.AfterReturning"></bean>

测试类:
public class TestAop extends BaseAopTest{
@Autowired
Object proxyFactoryBean;

@Test
public void test(){
    AopService aopService = (AopService) proxyFactoryBean;
    aopService.helloword("xiaoming");
}

}
问题是:在容器初始化的时候afterReturning会自动执行,但是这个方法我已经打了断点,但是不会进行debug,打印如下:
这是返回方法:当前正在执行toStringcom.example.demo.service.impl.AopServiceImpl@2a5b3fee[Ljava.lang.Object;@7c1e2a2dcom.example.demo.service.impl.AopServiceImpl@2a5b3fee
这是返回方法:当前正在执行toStringcom.example.demo.service.impl.AopServiceImpl@2a5b3fee[Ljava.lang.Object;@52d645b1com.example.demo.service.impl.AopServiceImpl@2a5b3fee
这是返回方法:当前正在执行toStringcom.example.demo.service.impl.AopServiceImpl@2a5b3fee[Ljava.lang.Object;@2101b44acom.example.demo.service.impl.AopServiceImpl@2a5b3fee
这是返回方法:当前正在执行toStringcom.example.demo.service.impl.AopServiceImpl@2a5b3fee[Ljava.lang.Object;@2cc3ad05com.example.demo.service.impl.AopServiceImpl@2a5b3fee
这是返回方法:当前正在执行toStringcom.example.demo.service.impl.AopServiceImpl@2a5b3fee[Ljava.lang.Object;@710b18a6com.example.demo.service.impl.AopServiceImpl@2a5b3fee
我后来查看了JdkDynamicAopProxy的invoke方法的method变量,发现是如下:
第一次public abstract java.lang.Class org.springframework.core.DecoratingProxy.getDecoratedClass()
以后都是public boolean java.lang.Object.equals(java.lang.Object),就是每打印一次“这是返回方法:当前正在执行”,这个JdkDynamicAopProxy的invoke方法就执行一次,只有真正的执行目标方法的时候afterReturning才会进入断点并且目标方法才是helloword,自动执行的方法都是toString,那么这个afterReturning不是一点用都没有吗?还是我写错了代码,请各位帮忙解答下

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值