深入理解Spring Aop的執(zhí)行順序
首先回憶一下 AOP 的常用注解
- @Before:前置通知:目標方法之前執(zhí)行
- @After:后置通知:目標方法之后執(zhí)行
- @AfterReturning:返回后通知:執(zhí)行方法結束前執(zhí)行
- @AfterThrowing:異常通知:出現(xiàn)異常時執(zhí)行
- @Around:環(huán)繞通知:環(huán)繞目標方法執(zhí)行
Spring4 中aop正常順序 + 異常順序
try{
@Before
method.invoke(obj, args);
@AfterReturning
}catch(){
@AfterThrowing
}finally{
@After
}
正常執(zhí)行:@Before(前置通知) ====>@After(后置通知) ====>@AfterReturning(正常返回)
異常執(zhí)行:@Before(前置通知) ====>@After(后置通知) ====>@AfterThrowing(方法異常)
另外如果還配置有環(huán)繞通知,則環(huán)繞通知的前置處理先于@Before執(zhí)行
環(huán)繞通知的后置處理也先于@After、@AfterReturning、@AfterThrowing執(zhí)行
正常結果:
環(huán)繞前置處理 @Before前置通知 invokeMethod() 環(huán)繞通知后置處理 @After后置通知 @AfterReturning / @AfterThrowing
異常結果:
環(huán)繞前置處理 @Before前置通知 @After后置通知 @AfterReturning / @AfterThrowing
Spring5 中aop正常順序 + 異常順序
正常執(zhí)行:@Before(前置通知) ====>@AfterReturning(正常返回) ====>@After(后置通知)
異常執(zhí)行:@Before(前置通知) ====>@AfterThrowing(方法異常) ====>@After(后置通知)
加上環(huán)繞通知的正常執(zhí)行結果:
環(huán)繞前置處理 @Before前置通知 invokeMethod() @AfterReturning / @AfterThrowing @After后置通知 環(huán)繞通知后置處理
加上環(huán)繞通知的異常執(zhí)行結果:
環(huán)繞前置處理 @Before前置通知 @AfterReturning / @AfterThrowing @After ```## Spring Aop的執(zhí)行順序
首先回憶一下 `AOP` 的常用注解
+ @Before:前置通知:目標方法之前執(zhí)行
+ @After:后置通知:目標方法之后執(zhí)行
+ @AfterReturning:返回后通知:執(zhí)行方法結束前執(zhí)行
+ @AfterThrowing:異常通知:出現(xiàn)異常時執(zhí)行
+ @Around:環(huán)繞通知:環(huán)繞目標方法執(zhí)行
> Spring4 中aop正常順序 + 異常順序
try{
@Before
method.invoke(obj, args);
@AfterReturning
}catch(){
@AfterThrowing
}finally{
@After
}
正常執(zhí)行:@Before(前置通知) ====>@After(后置通知) ====>@AfterReturning(正常返回)
異常執(zhí)行:@Before(前置通知) ====>@After(后置通知) ====>@AfterThrowing(方法異常)
另外如果還配置有環(huán)繞通知,則環(huán)繞通知的前置處理先于@Before執(zhí)行
環(huán)繞通知的后置處理也先于@After、@AfterReturning、@AfterThrowing執(zhí)行
正常結果:
環(huán)繞前置處理 @Before前置通知 invokeMethod() 環(huán)繞通知后置處理 @After后置通知 @AfterReturning / @AfterThrowing
異常結果:
環(huán)繞前置處理 @Before前置通知 @After后置通知 @AfterReturning / @AfterThrowing
Spring5 中aop正常順序 + 異常順序
正常執(zhí)行:@Before(前置通知) ====>@AfterReturning(正常返回) ====>@After(后置通知)
異常執(zhí)行:@Before(前置通知) ====>@AfterThrowing(方法異常) ====>@After(后置通知)
加上環(huán)繞通知的正常執(zhí)行結果:
環(huán)繞前置處理 @Before前置通知 invokeMethod() @AfterReturning / @AfterThrowing @After后置通知 環(huán)繞通知后置處理
加上環(huán)繞通知的異常執(zhí)行結果:
環(huán)繞前置處理 @Before前置通知 @AfterReturning / @AfterThrowing @After
到此這篇關于深入理解Spring Aop的執(zhí)行順序的文章就介紹到這了,更多相關Spring Aop執(zhí)行順序內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
使用java8 API遍歷過濾文件目錄及子目錄和隱藏文件示例詳解
這篇文章主要介紹了使用java8API遍歷過濾文件目錄及子目錄及隱藏文件示例詳解,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2020-07-07
SpringBoot+WebSocket實現(xiàn)即時通訊功能(Spring方式)
今天給大家分享一個SpringBoot+WebSocket實現(xiàn)即時通訊功能(Spring方式),WebSocket是一種在單個TCP連接上進行全雙工通信的協(xié)議,文章通過代碼示例給大家介紹的非常詳細,需要的朋友可以參考下2023-10-10
解決Springboot get請求是參數(shù)過長的情況
這篇文章主要介紹了解決Springboot get請求是參數(shù)過長的情況,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2020-09-09
@SpringBootConfiguration重復加載報錯問題解決
@SpringBootApplication?注解的?exclude?屬性用于排除特定的自動配置類,而不是用于排除主配置類本身,因此,不能通過?exclude?屬性來排除主配置類的加載,這篇文章主要介紹了@SpringBootConfiguration重復加載報錯,需要的朋友可以參考下2024-08-08

