自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

非Spring管理Bean如何添加AOP呢?

開發(fā) 前端
首先要清楚的是AOP的底層實(shí)現(xiàn)原理就是字節(jié)碼,我們只需要從字節(jié)碼層面,就一定可以解決這樣的問題。因此可以利用編譯期增強(qiáng)和運(yùn)行期增強(qiáng),常見的方案有兩種,一種Java Agent技術(shù),另一種 AspectJ方案。

[[357003]]

 前幾天有個朋友問了一個問題,覺得可以給大家分享一下。

問題如下圖

歸其根本這是個歷史項(xiàng)目,里面有很多的類并沒有交給spring管理,但現(xiàn)在需要統(tǒng)一添加日志。

面對這樣的問題,其實(shí)只要了解AOP的原理,就會有多種方法。AOP都是基于動態(tài)代理來實(shí)現(xiàn),而動態(tài)代理常見的就是cglib和java動態(tài)代理,不了解的可以看下之前干貨君寫的文章

  • java動態(tài)代理為什么需要基于接口
  • cglib動態(tài)代理對類沒有任何限制嗎?

但此兩種方法似乎在這樣的場景不好實(shí)現(xiàn),需要修改大量的代碼,那么有沒有什么好的方案呢?

答案當(dāng)然是有。

首先要清楚的是AOP的底層實(shí)現(xiàn)原理就是字節(jié)碼,我們只需要從字節(jié)碼層面,就一定可以解決這樣的問題。因此可以利用編譯期增強(qiáng)和運(yùn)行期增強(qiáng),常見的方案有兩種,一種Java Agent技術(shù),另一種 AspectJ方案。

Java Agent

Java Agent中文名字叫做java 探針,可以在運(yùn)行java時指定探針程序,對原程序無侵入,常見的一些APM工具都會這樣,如skywalking,后續(xù)有機(jī)會給大家介紹下。如下圖


java agent的主要原理就是利用JVMTI(JVM Tool Interface),JVM用來暴露一些供用戶擴(kuò)展的接口集合,因此可以在此處做一些運(yùn)行期字節(jié)碼增強(qiáng)。

Java Agent內(nèi)容比較多,有很多大家熟悉的工具都是基于它去做的,例如阿里的arthas。本文就不介紹了,后期會給大家詳細(xì)介紹下Java Agent。

AspectJ方案

可以利用aspectj + javac來編譯織入代碼,也可以利用maven插件aspectj-maven-plugin,下面利用AspectJ注解 + aspectj-maven-plugin來實(shí)戰(zhàn)一下。

aspectj-maven-plugin官網(wǎng) http://www.mojohaus.org/aspectj-maven-plugin/usage.html

引入依賴

編譯增強(qiáng),依賴此jar

 

  1. import org.aspectj.lang.annotation.Aspect; 
  2.  
  3. import org.aspectj.lang.annotation.Before; 
  4.  
  5. import org.aspectj.lang.annotation.Pointcut; 
  6.  
  7. @Aspect 
  8.  
  9. public class Aop { 
  10.  
  11.  
  12.  
  13. @Pointcut("execution(* com.ganhuojun.gracefulshutdown.controller..*.*(..))"
  14.  
  15. public void pointcut1(){ 
  16.  
  17.  
  18.  
  19.  
  20.  
  21.  
  22. @Before("pointcut1()"
  23.  
  24. public void before(){ 
  25.  
  26. System.out.println("controller before"); 
  27.  
  28.  

 

定義注解

注意:該注解不要交給spring管理

  1. <plugin> 
  2.  
  3. <groupId>org.codehaus.mojo</groupId> 
  4.  
  5. <artifactId>aspectj-maven-plugin</artifactId> 
  6.  
  7. <version>1.11</version> 
  8.  
  9. <configuration> 
  10.  
  11. <complianceLevel>1.8</complianceLevel> 
  12.  
  13. <source>1.8</source> 
  14.  
  15. <!--<showWeaveInfo>true</showWeaveInfo>--> 
  16.  
  17. <!--<Xlint>ignore</Xlint>--> 
  18.  
  19. <encoding>UTF-8</encoding> 
  20.  
  21. <sources> 
  22.  
  23. <source> 
  24.  
  25. <basedir>src/main/java</basedir> 
  26.  
  27. <!--此處使用include一致會導(dǎo)致織入失敗,暫時未找到好的解決辦法,不寫則引用所有的Aspect--> 
  28.  
  29. <!--<includes>--> 
  30.  
  31. <!--<include>**/Aop.java</include>--> 
  32.  
  33. <!--<include>**/ControllerAop.aj</include>--> 
  34.  
  35. <!--</includes>--> 
  36.  
  37. <excludes> 
  38.  
  39. <exclude>**/ServiceAop.java</exclude> 
  40.  
  41. </excludes> 
  42.  
  43. </source> 
  44.  
  45. </sources> 
  46.  
  47. </configuration> 
  48.  
  49. <executions> 
  50.  
  51. <execution> 
  52.  
  53. <goals> 
  54.  
  55. <goal>compile</goal> 
  56.  
  57. </goals> 
  58.  
  59. </execution> 
  60.  
  61. </executions> 
  62.  
  63. </plugin> 

 

 配置maven插件

  1. <plugin> 
  2.  
  3. <groupId>org.codehaus.mojo</groupId> 
  4.  
  5. <artifactId>aspectj-maven-plugin</artifactId> 
  6.  
  7. <version>1.11</version> 
  8.  
  9. <configuration> 
  10.  
  11. <complianceLevel>1.8</complianceLevel> 
  12.  
  13. <source>1.8</source> 
  14.  
  15. <!--<showWeaveInfo>true</showWeaveInfo>--> 
  16.  
  17. <!--<Xlint>ignore</Xlint>--> 
  18.  
  19. <encoding>UTF-8</encoding> 
  20.  
  21. <sources> 
  22.  
  23. <source> 
  24.  
  25. <basedir>src/main/java</basedir> 
  26.  
  27. <!--此處使用include一致會導(dǎo)致織入失敗,暫時未找到好的解決辦法,不寫則引用所有的Aspect--> 
  28.  
  29. <!--<includes>--> 
  30.  
  31. <!--<include>**/Aop.java</include>--> 
  32.  
  33. <!--<include>**/ControllerAop.aj</include>--> 
  34.  
  35. <!--</includes>--> 
  36.  
  37. <excludes> 
  38.  
  39. <exclude>**/ServiceAop.java</exclude> 
  40.  
  41. </excludes> 
  42.  
  43. </source> 
  44.  
  45. </sources> 
  46.  
  47. </configuration> 
  48.  
  49. <executions> 
  50.  
  51. <execution> 
  52.  
  53. <goals> 
  54.  
  55. <goal>compile</goal> 
  56.  
  57. </goals> 
  58.  
  59. </execution> 
  60.  
  61. </executions> 
  62.  
  63. </plugin> 

 

 排除spring的aop

如果對spring aop比較熟悉的都知道,spring的aop也是基于AspectJ的,因此需要exclude的,已經(jīng)配置到mavn的地方了。

編譯&運(yùn)行&測試

編譯后class文件已經(jīng)被織入了相關(guān)代碼,如下圖


運(yùn)行相關(guān)日志輸出如下

 說明功能已經(jīng)實(shí)現(xiàn)。

 

責(zé)任編輯:姜華 來源: 今日頭條
相關(guān)推薦

2024-05-28 07:55:31

SpringBean用域

2021-05-06 07:58:57

Spring BeanIOCAOP

2021-03-08 08:40:25

Spring Bean 創(chuàng)建單例對象

2009-06-19 13:28:30

Spring AOPSpring 2.0

2022-06-07 07:58:45

SpringSpring AOP

2023-11-03 08:19:18

SpringBean容器

2009-06-22 10:41:34

Spring.AOP

2022-02-17 13:39:09

AOP接口方式

2023-11-27 08:17:05

SpringJava

2023-10-16 11:12:29

2024-05-29 08:19:03

2022-06-08 08:04:28

Springservicerepository

2009-06-19 11:09:27

Spring AOP

2009-09-29 10:00:40

Spring AOP框

2023-07-29 22:11:58

Spring容器Component

2022-05-27 08:25:55

容器Spring

2021-05-11 07:42:59

BeanSpring屬性

2022-06-23 10:47:57

Spring容器工具

2024-12-24 14:01:10

2023-03-29 08:24:30

點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號