1、假如UserService中存在被增强的public 普通方法,那么spring ioc时就会创建对应的代理对象放置到容器中;
2、那么Controller中注入的userService就是代理对象;
@Service
public class UserService {
@Transactional
public void f2(String userName) {
System.out.println("Add user2: " + userName);
}
public final void f1(String userName) {
// something
this.f2(userName);
}
}
3、如上述代码调用关系所示,如果controller中调用的是方法f1,对f1加上final即可解决f2 aop失效的问题;
4、因f1是final修饰的方法,不可被增强,而确切的知道controller中的userService Bean是代理对象;
5、固在执行f1方法时不会让spring有机会替换执行方法的对象为【targetObject】;
6、所以f1中的this依旧是controller中的那个注入的代理对象;
7、所以f1中嵌套调用f2时,事务依旧生效。需要注意的是:f1上没有其它的增强逻辑(不然会导致f1上的增强逻辑失效);f2是public修饰;