AOP多次執行原因分析:
-
一個AOP多次執行,原因:產生重複代理了,典型的是和shiro集成。一般配置<aop:aspectj-autoproxy proxy-target-class="true"/>,這樣會自動創建一個AspectJAwareAdvisorAutoProxyCreator對象。如果shiro中配置了DefaultAdvisorAutoProxyCreator就會和aop命名空間創建的ProxyCreator產生衝突(參考AopNamespaceHandler),解決方法是去掉shiro的這個配置,shiro運行不受影響。參考https://blog.csdn.net/wangjun5159/article/details/51824171。
-
jdk代理和cglib代理同時存在,解決方法:去掉jdk代理,全部走cglib代理。spring aop全部是代理,不管jdk還是cglib。參考https://stackoverflow.com/questions/1606559/spring-aop-vs-aspectj。
-
配置文件重複加載,錯誤配置 <import resource="classpath*:/spring/applicationContext*.xml" />,這個會導致applicatioinContext開頭的配置文件會被加載多次,改成
<import resource="classpath:/spring/applicationContext*.xml" />
https://www.jianshu.com/p/50c39f3408eb
https://www.jianshu.com/p/0478bf7a99f5