溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

非Spring管理Bean怎么添加AOP

發(fā)布時(shí)間:2021-09-06 17:57:45 來源:億速云 閱讀:565 作者:小新 欄目:web開發(fā)

這篇文章主要為大家展示了“非Spring管理Bean怎么添加AOP”,內(nèi)容簡(jiǎn)而易懂,條理清晰,希望能夠幫助大家解決疑惑,下面讓小編帶領(lǐng)大家一起研究并學(xué)習(xí)一下“非Spring管理Bean怎么添加AOP”這篇文章吧。

問題如下圖

非Spring管理Bean怎么添加AOP

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

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

  • java動(dòng)態(tài)代理為什么需要基于接口

  • cglib動(dòng)態(tài)代理對(duì)類沒有任何限制嗎?

但此兩種方法似乎在這樣的場(chǎng)景不好實(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時(shí)指定探針程序,對(duì)原程序無侵入,常見的一些APM工具都會(huì)這樣,如skywalking,后續(xù)有機(jī)會(huì)給大家介紹下。如下圖

非Spring管理Bean怎么添加AOP

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

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

import org.aspectj.lang.annotation.Aspect;  import org.aspectj.lang.annotation.Before;  import org.aspectj.lang.annotation.Pointcut;  @Aspect  public class Aop {    @Pointcut("execution(* com.ganhuojun.gracefulshutdown.controller..*.*(..))")  public void pointcut1(){    }    @Before("pointcut1()")  public void before(){  System.out.println("controller before");  }  }

定義注解

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

<plugin>  <groupId>org.codehaus.mojo</groupId>  <artifactId>aspectj-maven-plugin</artifactId>  <version>1.11</version>  <configuration>  <complianceLevel>1.8</complianceLevel>  <source>1.8</source>  <!--<showWeaveInfo>true</showWeaveInfo>-->  <!--<Xlint>ignore</Xlint>-->  <encoding>UTF-8</encoding>  <sources>  <source>  <basedir>src/main/java</basedir>  <!--此處使用include一致會(huì)導(dǎo)致織入失敗,暫時(shí)未找到好的解決辦法,不寫則引用所有的Aspect-->  <!--<includes>-->  <!--<include>**/Aop.java</include>-->  <!--<include>**/ControllerAop.aj</include>-->  <!--</includes>-->  <excludes>  <exclude>**/ServiceAop.java</exclude>  </excludes>  </source>  </sources>  </configuration>  <executions>  <execution>  <goals>  <goal>compile</goal>  </goals>  </execution>  </executions>  </plugin>

 配置maven插件

<plugin>  <groupId>org.codehaus.mojo</groupId>  <artifactId>aspectj-maven-plugin</artifactId>  <version>1.11</version>  <configuration>  <complianceLevel>1.8</complianceLevel>  <source>1.8</source>  <!--<showWeaveInfo>true</showWeaveInfo>-->  <!--<Xlint>ignore</Xlint>-->  <encoding>UTF-8</encoding>  <sources>  <source>  <basedir>src/main/java</basedir>  <!--此處使用include一致會(huì)導(dǎo)致織入失敗,暫時(shí)未找到好的解決辦法,不寫則引用所有的Aspect-->  <!--<includes>-->  <!--<include>**/Aop.java</include>-->  <!--<include>**/ControllerAop.aj</include>-->  <!--</includes>-->  <excludes>  <exclude>**/ServiceAop.java</exclude>  </excludes>  </source>  </sources>  </configuration>  <executions>  <execution>  <goals>  <goal>compile</goal>  </goals>  </execution>  </executions>  </plugin>

 排除spring的aop

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

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

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

非Spring管理Bean怎么添加AOP

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

非Spring管理Bean怎么添加AOP

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

以上是“非Spring管理Bean怎么添加AOP”這篇文章的所有內(nèi)容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內(nèi)容對(duì)大家有所幫助,如果還想學(xué)習(xí)更多知識(shí),歡迎關(guān)注億速云行業(yè)資訊頻道!

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI