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

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

詳解spring中aop不生效的幾種解決辦法

瀏覽:22日期:2023-08-31 15:54:31

先看下這個問題的背景:假設有一個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中aop不生效的幾種解決辦法的文章就介紹到這了,更多相關spring中aop不生效內容請搜索好吧啦網以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持好吧啦網!

作者:菩提樹下的楊過出處:http://yjmyzz.cnblogs.com

標簽: Spring
相關文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
日本黄色精品| 国产精品乱战久久久| 精品国产乱码久久久| 国产精品2区| 精品国产亚洲一区二区三区| 国产精品草草| 免费观看亚洲天堂| 精品视频亚洲| 91精品一区二区三区综合| 91精品国产91久久久久久黑人| 国产欧美一区二区三区精品酒店| 成人日韩在线| 日韩精品午夜| 夜夜精品视频| 99视频+国产日韩欧美| 免费观看在线综合| 久久国产精品久久久久久电车| 欧美在线影院| 亚洲在线久久| 国产色99精品9i| 国产精品成久久久久| 免费人成黄页网站在线一区二区| 日本在线不卡视频| 国产精品毛片久久久| 日韩.com| 天堂av在线| 精品一区欧美| 在线精品视频一区| 国产精品久久久久久av公交车| 久久wwww| 免费在线小视频| 蜜臀av免费一区二区三区| 国产美女精品| 亚洲一卡久久| 日本va欧美va精品发布| 老色鬼精品视频在线观看播放| 岛国av在线播放| 欧美日韩四区| 国产免费播放一区二区| 青青青免费在线视频| 久久久夜精品| 在线一区二区三区视频| 国产精品欧美大片| 久久精品九色| 欧美~级网站不卡| 亚洲欧洲美洲国产香蕉| 国产精品第一国产精品| 婷婷激情一区| 日韩精品视频中文字幕| 国产一区二区三区视频在线| 在线日韩欧美| 日本免费一区二区视频| 桃色av一区二区| 亚洲久久视频| 中文在线а√天堂| 免播放器亚洲| 久久永久免费| 亚洲欧美视频一区二区三区| 国产欧美啪啪| 亚洲激情五月| 美腿丝袜在线亚洲一区| 在线国产一区| 麻豆高清免费国产一区| 亚洲激情黄色| 精品国产99| 亚洲精品自拍| 91精品一区二区三区综合在线爱 | 国产精品xxxav免费视频| 高清av不卡| 亚洲三级在线| 日韩一区二区三区免费播放| 亚洲精品乱码| 日韩欧美一区二区三区在线观看| 日本亚洲欧美天堂免费| 韩国精品主播一区二区在线观看| 日韩一区二区三区高清在线观看| 日韩欧美一区二区三区免费看| 亚洲v天堂v手机在线| 日韩一区二区三区免费播放| 日韩二区三区在线观看| 免费av一区| 精品亚洲精品| 亚洲另类av| 四虎884aa成人精品最新| 亚洲精品成人一区| 亚洲天堂成人| 精品一区二区三区免费看| 午夜电影一区| 欧美日韩在线网站| 久久99久久人婷婷精品综合| 一区二区三区四区在线观看国产日韩| 中文字幕在线官网| 国产精品一区高清| 视频一区在线播放| 国产99亚洲| 国产精品伦理久久久久久| 日本欧美一区二区在线观看| av成人国产| 99久久精品国产亚洲精品| 国产美女视频一区二区| 久久国产精品久久久久久电车| 色天使综合视频| 水蜜桃精品av一区二区| 国产精品一区三区在线观看| 三级在线观看一区二区 | 精品视频一区二区三区在线观看| 日韩精品视频网| 亚洲欧美日韩国产一区| 成人羞羞在线观看网站| 精品九九在线| 欧美激情麻豆| 欧美日韩一区二区三区四区在线观看 | 久久国产精品色av免费看| 快she精品国产999| 午夜影院欧美| 亚洲大片在线| 久久国产电影| 欧美成人基地| 亚洲成人av观看| 久久久精品午夜少妇| 久久只有精品| 精品久久国产一区| 国产精品13p| 神马午夜在线视频| 欧美精品高清| 欧美日韩亚洲在线观看| 99精品美女| 天堂日韩电影| 99久久激情| 自拍日韩欧美| 日韩亚洲国产欧美| 日韩午夜av在线| 亚洲欧美日韩在线观看a三区| 久久高清免费观看| 亚洲综合小说| 亚洲一区二区日韩| 亚洲精品福利| 国产精品一区二区三区www| 国产精品sss在线观看av| 国产精品伦一区二区| 美女在线视频一区| 成人国产精品| 91精品国产福利在线观看麻豆| 136国产福利精品导航网址| 夜夜嗨一区二区| 亚洲精品无吗| 国产精品久久久久77777丨| 久久97视频| 欧美日韩视频免费观看| 婷婷色综合网| 中日韩男男gay无套| 日韩一区精品字幕| 亚洲区国产区| 久久国产生活片100| 精品视频亚洲| 日韩精品一卡| 免费不卡在线视频| 欧美日韩调教| 欧美男人天堂| 丝袜国产日韩另类美女| 欧美日本精品| 综合日韩av| 99国产成+人+综合+亚洲欧美| 日本v片在线高清不卡在线观看| 国产精品极品国产中出| 久久精品国产网站| 久久九九精品| 热久久国产精品| 欧美在线看片| 日韩电影二区| 首页国产欧美日韩丝袜| 国产亚洲观看| 欧美aa在线观看| 男女男精品视频网| 欧美黄色一区二区| 欧美精品一区二区三区精品| 日韩中文字幕一区二区高清99| 欧美精品91| av亚洲在线观看| 国产精品天天看天天狠| 亚洲精品**中文毛片| 亚洲一区日本| 久久伊人亚洲| 国产精品腿扒开做爽爽爽挤奶网站| 日韩av不卡一区二区| 欧美香蕉视频| 91欧美精品| 日本欧美不卡| 日韩av成人高清| 激情欧美日韩一区| 91成人精品观看| 欧美一区二区性| 国产欧美日韩在线一区二区| 精精国产xxxx视频在线野外| 日韩精品视频中文字幕| 97国产精品| 一二三区精品| 日韩一区二区三区免费播放| 日韩二区三区四区| 999国产精品|