Spring注解配置AOP導致通知執行順序紊亂解決方案
今天在測試Spring的AOP時,發現使用注解配置AOP的方式會導致通知的執行順序紊亂。【最終通知居然在異常通知之前執行了】
測試代碼
(1)定義TargetInterface目標接口
public interface TargetInterface {public abstract void targetProxy();}
(2)定義TargetImpl目標類
@Component('target')public class TargetImpl implements TargetInterface {public void targetProxy() { System.out.println('target proxy ......'); int i = 1/0;//異常}}
(3)定義切面類(內含增強方法)
@Component('myAspect')//定義切面類@Aspect//聲明當前類是切面類public class TargetAspect {//定義切點表達式@Pointcut('execution(* com.ahzyy.target.impl.*.*(..))')public void pt() {}@Before('pt()')public void before() { System.out.println('前置通知......');}@After('pt()')public void after() { System.out.println('最終通知......');}@AfterReturning('pt()')public void afterReturning() { System.out.println('后置通知......');}@AfterThrowing('pt()')public void afterThrowing() { System.out.println('異常通知......');}}
(4)配置applicationContextAnno.xml文件
<!--配置組件掃描的包--><context:component-scan base-package='com.ahzyy'/><!--配置AOP自動代理--><aop:aspectj-autoproxy/>
(5)定義測試類
@RunWith(SpringJUnit4ClassRunner.class)//@ContextConfiguration('classpath:applicationContext.xml')@ContextConfiguration('classpath:applicationContextAnno.xml')public class AopTest {@Autowiredprivate TargetInterface target;@Testpublic void test01() { target.targetProxy();}}
(6)運行結果:
【最終通知在異常通知之前執行了!!!】
(7)解決方法:
(7.1)使用xml配置方式配置AOP;
(7.2)注解使用@Around(環繞通知)方式配置AOP(修改TargetAspect類使用環繞通知);
@Component('myAspect')//定義切面類@Aspect//聲明當前類是切面類public class TargetAspect {//定義切點表達式@Pointcut('execution(* com.ahzyy.target.impl.*.*(..))')public void pt() {}@Around('pt()')public Object aroundNotice(ProceedingJoinPoint pjp) { System.out.println('環繞通知'); Object result = null; before();//前置通知 try { result = pjp.proceed(); afterReturning();//后置通知 } catch (Throwable throwable) {afterThrowing();//異常通知 throwable.printStackTrace(); } after();//最終通知 return result;}public void before() { System.out.println('前置通知......');}public void afterReturning() { System.out.println('后置通知......');}public void afterThrowing() { System.out.println('異常通知......');}public void after() { System.out.println('最終通知......');}}
(7.3)運行結果
[運行順序正確]
以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持好吧啦網。
相關文章:
1. Intellij IDEA 2019 最新亂碼問題及解決必殺技(必看篇)2. 關于HTML5的img標簽3. java實現圖形化界面計算器4. 《javascript設計模式》學習筆記三:Javascript面向對象程序設計單例模式原理與實現方法分析5. IntelliJ IDEA設置條件斷點的方法步驟6. ASP.NET MVC獲取多級類別組合下的產品7. ASP.NET MVC解決上傳圖片臟數據的方法8. 5個HTML5的常用本地存儲方式詳解與介紹9. ASP基礎入門第七篇(ASP內建對象Response)10. 原生js XMLhttprequest請求onreadystatechange執行兩次的解決
