目标类及方法:
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不是一点用都没有吗?还是我写错了代码,请各位帮忙解答下