1、问题描述
最近在开发中遇到一个问题,当在Service中定义了一个方法并且切入之后,从Controller里面调用该方法可以实现切入,但是当在同一个Service中实现另一方法并调用改方法时却无法切入。
Controller -> Service.A() aop可以切入方法A
Controller -> Service.A() -> Service.B() aop无法切入方法B
2、问题原因
当controller构建实例的时候,注入serviceTest实例的时候,发现其有切面,产生了代理类serviceTestProxy并注入给了controller。实际调用的时序图如下:
必须要调用代理类才会被切进去,这样就导致B()方法根本没有被切面切入。虽然controller第一次调用的是代理类,但是在调用B()方法的时候是调用的service实例内部的B()方法,所以切面没有生效。
3、解决方式
- 在需要切入的类上方添加如下注解
@EnableAspectJAutoProxy(exposeProxy = true)
- 使用AopContext.currentProxy()调用方法B
// 无法切到方法B的伪代码
public class ServiceTest {
public void A() {
...
this.B();
...
}
public void B() {
...
}
}
// 修改后可以切到方法B的伪代码
@EnableAspectJAutoProxy(exposeProxy = true)
public class ServiceTest {
public void A() {
...
((Test) AopContext.currentProxy()).B();
...
}
public void B() {
...
}
}