日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

您的位置:首頁技術(shù)文章
文章詳情頁

Spring aop失效的幾種解決方案

瀏覽:203日期:2023-09-06 13:16:42

先看下這個問題的背景:假設(shè)有一個spring應(yīng)用,開發(fā)人員希望自定義一個注解@Log,可以加到指定的方法上,實現(xiàn)自動記錄日志(入?yún)ⅰ⒊鰠ⅰ㈨憫?yīng)耗時這些)

package com.cnblogs.yjmyzz.springbootdemo.aspect; import java.lang.annotation.ElementType;import java.lang.annotation.Retention;import java.lang.annotation.RetentionPolicy;import java.lang.annotation.Target; @Retention(RetentionPolicy.RUNTIME)@Target(ElementType.METHOD)public @interface Log { }

然后再寫一個Aspect來解析這個注解,對打了Log注解的方法進行增強處理 

package com.cnblogs.yjmyzz.springbootdemo.aspect; import org.aspectj.lang.JoinPoint;import org.aspectj.lang.ProceedingJoinPoint;import org.aspectj.lang.annotation.Around;import org.aspectj.lang.annotation.Aspect;import org.aspectj.lang.annotation.Pointcut;import org.springframework.stereotype.Component; import java.lang.reflect.Method; @Component@Aspectpublic class LogAspect { @Pointcut('execution (* com.cnblogs.yjmyzz.springbootdemo.service..*.*(..))') public void logPointcut() { } @Around('logPointcut()') public void around(JoinPoint point) { String methodName = point.getSignature().getName(); Object[] args = point.getArgs(); Class<?>[] argTypes = new Class[point.getArgs().length]; for (int i = 0; i < args.length; i++) { argTypes[i] = args[i].getClass(); } Method method = null; try { method = point.getTarget().getClass().getMethod(methodName, argTypes); } catch (Exception e) { e.printStackTrace(); } //獲取方法上的注解 Log log = method.getAnnotation(Log.class); if (log != null) { //演示方法執(zhí)行前,記錄一行日志 System.out.println('before:' + methodName); } try { //執(zhí)行方法 ((ProceedingJoinPoint) point).proceed(); } catch (Throwable throwable) { throwable.printStackTrace(); } finally { if (log != null) {//演示方法執(zhí)行后,記錄一行日志System.out.println('after:' + methodName); } } }}

寫一個測試Service類:

package com.cnblogs.yjmyzz.springbootdemo.service; import com.cnblogs.yjmyzz.springbootdemo.aspect.Log;import org.springframework.stereotype.Component; @Componentpublic class HelloService { @Log public void sayHi(String msg) { System.out.println('tsayHi:' + msg); } public void anotherSayHi(String msg) { this.sayHi(msg); } }

最后來跑一把:

package com.cnblogs.yjmyzz.springbootdemo; import com.cnblogs.yjmyzz.springbootdemo.service.HelloService;import org.springframework.context.annotation.AnnotationConfigApplicationContext;import org.springframework.context.annotation.ComponentScan;import org.springframework.context.annotation.Configuration;import org.springframework.context.annotation.EnableAspectJAutoProxy; /** * @author 菩提樹下的楊過 */@ComponentScan('com.cnblogs.yjmyzz')@Configuration@EnableAspectJAutoProxypublic class SampleApplication { public static void main(String[] args) { AnnotationConfigApplicationContext context = new AnnotationConfigApplicationContext(SampleApplication.class); HelloService helloService = context.getBean(HelloService.class); helloService.sayHi('hi-1'); System.out.println('n'); helloService.anotherSayHi('hi-2'); }}

輸出如下:

Spring aop失效的幾種解決方案

顯然HelloService中的anotherSayHi方法,并未被aop增強。 原因其實很簡單,了解AOP原理的同學想必都知道,AOP的實現(xiàn)有二類,如果是基于接口的,會采用動態(tài)代理,生成一個代理類,如果是基于類的,會采用CGLib生成子類,然后在子類中擴展父類中的方法。

Spring aop失效的幾種解決方案

本文中HelloService并不是一個接口,所以從上圖的斷點中可以看出,當Spring運行時,HelloService被增加為...EnhancerBySpringCGLib...。但是當調(diào)用到anotherSayHi時

Spring aop失效的幾種解決方案

方法的調(diào)用方,其實是原始的HelloSerfvice實例,即:是未經(jīng)過Spring AOP增強的對象實例。所以解決問題的思路就有了,想辦法用增強后的HelloService實例來調(diào)用!

方法一:用Autowired 注入自身的實例

Spring aop失效的幾種解決方案

這個方法,第一眼看上去感覺有些怪,自己注入自己,感覺有點象遞歸/死循環(huán)的搞法,但確實可以work,Spring在解決循環(huán)依賴上有自己的處理方式,避免了死循環(huán)。

方法二:從Spring上下文獲取增強后的實例引用

Spring aop失效的幾種解決方案

原理與方法一其實類似,不多解釋。

方法三: 利用AopContext

Spring aop失效的幾種解決方案

不過這個方法要注意的是,主類入口上,必須加上exporseProxy=true,參考下圖:

Spring aop失效的幾種解決方案

最后來驗證下這3種方法是否生效:

Spring aop失效的幾種解決方案

從運行結(jié)果上看,3種方法都可以解決這個問題。 

以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持好吧啦網(wǎng)。

標簽: Spring
相關(guān)文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
av资源亚洲| 国产精选在线| 日韩不卡视频在线观看| sm捆绑调教国产免费网站在线观看 | 亚洲成av人片一区二区密柚| 色爱综合网欧美| 国产剧情一区二区在线观看| 欧美另类中文字幕| 老司机精品在线| 在线天堂中文资源最新版| 日韩免费小视频| 亚洲作爱视频| 日本国产一区| 欧美好骚综合网| 欧美精品一区二区久久| 日韩精品一二三区| 777久久精品| 国产在线一区不卡| 欧洲在线一区| 香蕉久久久久久久av网站| 日本一区二区三区视频在线看| 亚洲乱码久久| 欧美日韩视频免费观看| 一区二区电影在线观看| 国产精品久久亚洲不卡| 香蕉人人精品| 欧美日韩一视频区二区| 婷婷丁香综合| 精品美女视频| 免费在线观看视频一区| 久久精品二区亚洲w码| 国产农村妇女精品一二区| 国产精品亚洲产品| 亚洲黄页一区| 精品国产乱码久久久久久樱花| 在线视频观看日韩| 日韩精品第二页| 好吊视频一区二区三区四区| 国产欧美自拍| 久热re这里精品视频在线6| 精品国产欧美日韩| 亚洲欧美在线综合| 一区久久精品| 亚洲黄色中文字幕| 国产精品资源| 亚洲精品国产日韩| 香蕉久久夜色精品国产| 亚洲精品国产嫩草在线观看 | 成人亚洲欧美| 国产精品亚洲一区二区在线观看| 日韩视频二区| 免费视频亚洲| 激情欧美一区二区三区| 日韩中文首页| av中文字幕在线观看第一页| 精品网站999| 久久麻豆视频| 福利欧美精品在线| 开心激情综合| 97人人精品| 亚洲精品一区三区三区在线观看| 一本大道色婷婷在线| 超碰在线99| 一区二区精品伦理...| 国产精品对白久久久久粗| 日韩高清在线不卡| 日本99精品| 国产精品久久久免费| 麻豆国产精品一区二区三区| 国产福利一区二区精品秒拍 | 亚洲国产福利| 成人精品中文字幕| 免费av一区| 日韩一区二区三免费高清在线观看| 日韩一区精品视频| 另类av一区二区| 亚洲精品美女| 国产欧美一区二区三区精品观看 | 日本久久成人网| 黑丝一区二区三区| 亚洲va久久| 国产精品xxx| 精品视频在线观看网站| 久久三级福利| 噜噜噜躁狠狠躁狠狠精品视频 | 在线精品视频一区| 国产精品午夜av| 亚洲精品高潮| 国产aa精品| 噜噜噜躁狠狠躁狠狠精品视频| 日韩av三区| av亚洲一区二区三区| 免费日韩视频| 精品国产亚洲一区二区三区大结局| 福利精品一区| 天海翼精品一区二区三区| 国产欧美日韩一区二区三区四区| 波多野结衣久久精品| 亚洲精品影视| 欧美 日韩 国产一区二区在线视频| 久久国产麻豆精品| 美女网站一区| 久久精品国产精品亚洲毛片| 国产视频久久| 日本а中文在线天堂| 日本91福利区| 欧美亚洲精品在线| 成人国产精品久久| 日本一区二区三区中文字幕| 色吊丝一区二区| 国产精品一区二区中文字幕| 亚洲免费福利| 久久伊人久久| 国产欧美另类| 日韩高清不卡在线| 久久av在线| 中文精品视频| 国产专区一区| 在线日韩欧美| 久久在线免费| 亚洲涩涩在线| 日韩精品久久久久久久电影99爱| 欧美a一区二区| 欧美一区=区三区| 日韩精品五月天| 日韩三级视频| 亚洲资源av| 久久高清免费观看| 一区二区三区午夜视频| 亚洲资源网站| 日本视频一区二区| 日韩av一级片| 国产精品www994| 福利一区二区| 激情婷婷久久| 丝袜a∨在线一区二区三区不卡| 99视频精品免费观看| 一区在线免费观看| 国产一区二区精品| 久久电影一区| 国产精品久久久久久久久久白浆| 蜜臀av性久久久久蜜臀aⅴ四虎| 综合激情网站| 精品一区二区三区亚洲| 日韩欧美网址| 国产精品嫩草99av在线| 蜜桃视频一区二区三区在线观看| 视频一区中文字幕精品| 国产乱码精品一区二区三区亚洲人 | 国产精品多人| 91精品国产91久久久久久黑人| 午夜在线一区| 国产日产高清欧美一区二区三区| 国产欧美日韩在线观看视频| 麻豆国产一区| 久久国产电影| 热久久久久久久| 精品亚洲成人| 欧美专区18| 精品一区视频| 激情自拍一区| 国产精品tv| 亚洲一区二区三区免费在线观看| 亚洲一二av| 国产情侣久久| 欧美色图一区| 国产日韩亚洲欧美精品| 婷婷激情一区| 国产亚洲精aa在线看| 五月综合激情| 国产精品亚洲产品| 国产毛片久久| 国产第一亚洲| 日韩精品福利一区二区三区| 在线手机中文字幕| 视频一区视频二区在线观看| 国产精品白丝一区二区三区| 午夜精品婷婷| 精品伊人久久| 亚洲尤物在线| 久久狠狠婷婷| 国产精品黄色片| 亚洲精品系列| 国产一区白浆| 欧美成人亚洲| 天堂av在线| 成人综合一区| 欧美黄色一区二区| 综合亚洲视频| 蜜桃久久久久久| 国产精品宾馆| 国产欧美自拍| 日韩精品视频中文字幕| 免费观看在线综合| 九色porny丨国产首页在线| 久久亚洲影院| 涩涩涩久久久成人精品| 蜜臀久久99精品久久久久久9 | 三级精品视频| 久久视频精品|