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

您的位置:首頁技術文章
文章詳情頁

Spring aop失效的幾種解決方案

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

先看下這個問題的背景:假設有一個spring應用,開發人員希望自定義一個注解@Log,可以加到指定的方法上,實現自動記錄日志(入參、出參、響應耗時這些)

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) { //演示方法執行前,記錄一行日志 System.out.println('before:' + methodName); } try { //執行方法 ((ProceedingJoinPoint) point).proceed(); } catch (Throwable throwable) { throwable.printStackTrace(); } finally { if (log != null) {//演示方法執行后,記錄一行日志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的實現有二類,如果是基于接口的,會采用動態代理,生成一個代理類,如果是基于類的,會采用CGLib生成子類,然后在子類中擴展父類中的方法。

Spring aop失效的幾種解決方案

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

Spring aop失效的幾種解決方案

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

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

Spring aop失效的幾種解決方案

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

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

Spring aop失效的幾種解決方案

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

方法三: 利用AopContext

Spring aop失效的幾種解決方案

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

Spring aop失效的幾種解決方案

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

Spring aop失效的幾種解決方案

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

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

標簽: Spring
相關文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
久久在线91| 免费看欧美美女黄的网站| 日本va欧美va精品| 亚洲三级网站| 日本欧美在线看| 亚洲在线观看| 欧美精品一二| 婷婷综合网站| 久久高清一区| 亚洲不卡视频| 国产欧美日韩精品一区二区免费| 欧美在线精品一区| 久久国产日韩欧美精品| 国产亚洲电影| 精品视频在线一区二区在线| 精品国产乱码久久久| 免费观看亚洲| 黄色亚洲大片免费在线观看| 最新日韩av| 亚洲精品视频一二三区| 欧美天堂在线| 国产中文欧美日韩在线| 亚洲www啪成人一区二区| av亚洲免费| 天海翼精品一区二区三区| 国产日韩1区| 国产一区二区精品福利地址| 久久精品99久久无色码中文字幕| 免费精品视频| 日韩高清一区在线| 国产suv精品一区二区四区视频| 久久久成人网| 亚洲另类av| 久久成人av| 91精品国产自产在线观看永久∴| 亚洲午夜国产成人| 国产午夜久久av| 久久夜夜操妹子| 免费美女久久99| 免费亚洲一区| 美女毛片一区二区三区四区| 中文字幕免费一区二区| 久久精品网址| 亚洲精品一区二区妖精| 日本欧美在线| 欧美日韩免费观看视频| 在线精品国产亚洲| 日韩成人免费| 男人的天堂久久精品| 国产精品777777在线播放| 久久影视一区| 青青青国产精品| 黄色aa久久| 一区二区91| 日韩伦理在线一区| 亚洲日韩视频| 日韩精品dvd| 日韩激情精品| 久久亚洲国产| 欧美a一区二区| av不卡在线看| 精品国产一区二区三区性色av| 99国产精品| 国产999精品在线观看| 亚洲午夜久久| 久久精品国产亚洲夜色av网站| 国产乱码精品一区二区三区四区| 日韩一区二区三区在线免费观看| 日本欧美大码aⅴ在线播放| 欧美性感美女一区二区| 国产精品第十页| 水野朝阳av一区二区三区| 国产成人精品免费视| 婷婷精品在线观看| 亚洲性图久久| 精品国产a一区二区三区v免费| 丝袜诱惑制服诱惑色一区在线观看| 国产偷自视频区视频一区二区| 日产欧产美韩系列久久99| 在线亚洲激情| 免费不卡中文字幕在线| 91看片一区| 免费一区二区三区在线视频| 国产精品亚洲人成在99www| 久久不射网站| 亚洲综合国产| 在线一区视频| 精品1区2区3区4区| 欧美日韩国产欧| 午夜欧美精品久久久久久久| 国产综合亚洲精品一区二| 久久精品影视| 1024精品一区二区三区| 久久精品国产亚洲夜色av网站| 视频小说一区二区| 欧美日中文字幕| 国产精品99免费看| 中文字幕日韩欧美精品高清在线| 综合激情婷婷| 日韩精品视频网| 欧美片网站免费| 国产精品大片免费观看| 久久只有精品| www.com.cn成人| 欧美日中文字幕| 夜夜精品视频| 亚洲精品影院在线观看| 日韩av资源网| 国产精品调教| 福利片在线一区二区| 午夜久久中文| 波多野结衣一区| 亚洲91视频| 快she精品国产999| 日韩高清欧美激情| 国产日韩欧美在线播放不卡| 精品国产aⅴ| 久久黄色影院| 久久亚洲影院| 国产欧美日韩一区二区三区在线| 麻豆视频一区二区| 高潮一区二区| 亚洲国产日韩欧美在线| 亚洲69av| 国产精品theporn| 日韩在线第七页| 99pao成人国产永久免费视频| 中文无码日韩欧| 国产图片一区| 另类专区亚洲| 99xxxx成人网| 18国产精品| 久久精品福利| 亚洲性视频h| 日韩激情av在线| 久久一区精品| 99久久www免费| 亚洲欧洲日韩| 国内精品亚洲| 伊人久久亚洲热| 97se亚洲| 日韩大片在线观看| 在线综合视频| 久久99久久人婷婷精品综合| 99精品电影| 日韩欧美中文字幕一区二区三区| 久久亚州av| 欧美日韩国产一区精品一区| 日韩av电影一区| 国产综合色区在线观看| 欧美资源在线| 国产suv精品一区二区四区视频| 亚洲美洲欧洲综合国产一区| 国产日韩中文在线中文字幕| 亚洲精品.com| 青草国产精品| 亚洲91精品| 日本成人在线网站| 亚洲播播91| 日韩一区精品| 色爱av综合网| 国产精品嫩模av在线| 婷婷成人在线| 国产日韩欧美中文在线| 久久中文字幕二区| 国产精品一区二区免费福利视频| 国产99久久| 免费一级欧美片在线观看网站| 99xxxx成人网| yellow在线观看网址| 日本成人中文字幕在线视频| 激情欧美国产欧美| 91精品美女| 国产视频一区在线观看一区免费| 里番精品3d一二三区| 日韩精品一二三四| 日韩精品2区| 国产福利资源一区| 亚洲深夜福利在线观看| 偷拍精品精品一区二区三区| 国产精品日韩精品在线播放| 视频一区二区国产| 日本在线精品| 欧美国产极品| 日韩一区精品字幕| 久久精品国产大片免费观看| 国产精品久一| 亚洲欧美日本视频在线观看| 久久中文字幕一区二区三区| 日本不卡高清| 黄色日韩精品| av高清一区| 麻豆成人综合网| 日韩国产在线一| 六月天综合网| 在线成人动漫av| 97精品国产| 国产精品videossex久久发布 | 欧美精品99| 亚洲91在线|