网上有很多解决方案,最简单最实用的方式是以下这种:
@Autowired
private ApplicationContext applicationContext;
@Override
public void testAop() {
// 从Spring容器中获取bean对象
TestService testService = applicationContext.getBean(TestService.class);
// 使用该bean对象去调用对应方法才会执行切面逻辑
testService.test();
}
// 该方法有切面逻辑
@Override
public void test() {
// 相关代码逻辑
}
原因:从controller来的Service能获取到动态代理,而从Service调用Service方法,Spring则无法获取动态代理。
问题就在于调用切面方法processInsert_db的方法是同一个类内部的。如果是其他类直接调用processInsert_db那么会走切面逻辑。因为AOP就是对原有的业务逻辑做一次增强,在原有代码的基础上在生成class文件的时候或者装在class是在JVM内生成一个代理代理对象,代理对象被@Autowired注入到其他类的引用里,所以当其他类调用时实际上使用的是代理对象,所以会触发切面逻辑。 但如果是类内部调用,使用的是对象本身,而不是代理对象,所以不走切面逻辑。