溫馨提示×

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

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

如何正確使用Aspect 的.aj 類

發(fā)布時(shí)間:2021-10-12 15:22:07 來(lái)源:億速云 閱讀:262 作者:iii 欄目:編程語(yǔ)言

本篇內(nèi)容主要講解“如何正確使用Aspect 的.aj 類”,感興趣的朋友不妨來(lái)看看。本文介紹的方法操作簡(jiǎn)單快捷,實(shí)用性強(qiáng)。下面就讓小編來(lái)帶大家學(xué)習(xí)“如何正確使用Aspect 的.aj 類”吧!

目錄


  • 一、前言

  • 二、滿腦子都是騷操作

    • 1. 遇到問(wèn)題

    • 2. 發(fā)現(xiàn)問(wèn)題

    • 3. 排查問(wèn)題

  • 三、如何正確使用 Aspect 的 .aj 類

    • 1. 安裝 AspectJ

    • 2. AspectJ 插件

    • 3. 添加依賴 aspectjrt.jar

    • 4. 配置AspectJ編譯器

    • 5. 案例測(cè)試

一、前言

說(shuō)來(lái)也是奇怪,只要是學(xué)編程的,從初次接觸的 Java 到安裝 JDK、IDEA、MYSQL, 再到接觸 Spring、MyBatis、RPC、MQ,哪怕有時(shí)候在淺的坑也會(huì)跳進(jìn)去嘗嘗鮮,一遍抓著頭發(fā),一手點(diǎn)著鼠標(biāo)也幾乎是你的常態(tài)。你的鍵盤里總是有很多被抓碎的頭發(fā)!

二、滿腦子都是騷操作

1. 遇到問(wèn)題

上周,謝飛機(jī)(化名)發(fā)過(guò)來(lái)了自己的手?jǐn)]的中間件源碼,說(shuō)這代碼都沒(méi)有啥怎么就不能切面呢?

如何正確使用Aspect 的.aj 類  
  • 最開始我大意了,讓謝飛機(jī)發(fā)了一些代碼截圖。
  • 看截圖的代碼,這完全就和我寫的中間件里的代碼一毛一樣,沒(méi)啥問(wèn)題呀,包路徑也能掃描到,咋就不能切面了?
  • 我說(shuō)你打個(gè)斷點(diǎn)調(diào)試下,看看怎么切不到了呢?嘿,調(diào)試了,直接通過(guò),就是沒(méi)切面到。
  • 此時(shí)我思考了JDK版本、環(huán)境配置、Spring上下文、切面的定義、包的路徑以及這小子是否忽悠我?
  • 最后我抱著這小子忽悠我的心里,把源碼要過(guò)來(lái)了。

2. 發(fā)現(xiàn)問(wèn)題

看了幾遍源碼沒(méi)發(fā)現(xiàn)問(wèn)題,開始調(diào)試,還真它哈拉哨的不進(jìn)這個(gè)切面,接下來(lái);

  • 謝飛機(jī)的源碼保留,復(fù)制出來(lái)一份新的。
  • 我的目的要先讓他跑起來(lái),在研究。接下來(lái)我把自己的工程里的     DoJoinPoint 拷貝過(guò)來(lái)粘貼進(jìn)去,噗察一下貼進(jìn)去了,沒(méi)提示替換,雖然有報(bào)錯(cuò)但兩個(gè)類能共存,如下:     如何正確使用Aspect 的.aj 類
    • 這就神奇了哈,我當(dāng)時(shí)懷疑是不它那      DoJoinPoint 不是一個(gè)正經(jīng) Java 類,路徑不對(duì)?有看不見的特殊字符?
  • 既然發(fā)現(xiàn)這個(gè)類不對(duì),那行先刪掉。讓程序先跑起來(lái),確保除了這個(gè)類其他的內(nèi)容沒(méi)有問(wèn)題,這樣也好排查問(wèn)題。
  • 還別說(shuō),去掉這個(gè)錯(cuò)誤類,程序可以正常運(yùn)行,攔截到切面內(nèi)容了。
  • 既然程序能跑了,我就想著這可以看看問(wèn)題出在哪了,沒(méi)想到就只打開個(gè)文件夾,就發(fā)現(xiàn)了一個(gè)神奇的     AJ!這貨壓根就不是 Java 類!     如何正確使用Aspect 的.aj 類
 

3. 排查問(wèn)題

要不是IDEA把 .aj 這貨顯示成 C 類的圖標(biāo),可能早就發(fā)現(xiàn)問(wèn)題了。緊接著把這錯(cuò)誤類的截圖發(fā)給了謝飛機(jī),問(wèn)它你是怎么創(chuàng)建的?他說(shuō)實(shí)話了

  • 謝飛機(jī)先說(shuō)自己偷懶了,哈哈哈,讓人怪不好意思的!
  • 他說(shuō)在創(chuàng)建     DoJoinPoint 時(shí),看到一個(gè) Aspect 的選項(xiàng),以為這個(gè)就是創(chuàng)建切面的快捷操作,如圖;     如何正確使用Aspect 的.aj 類
  • 創(chuàng)建完成以后發(fā)現(xiàn)有點(diǎn)不對(duì),不是 class 類型的,是個(gè) aspect,于是他手動(dòng)把 aspect 改成了 class,如圖;     如何正確使用Aspect 的.aj 類
  • 所以,謝飛機(jī)實(shí)際創(chuàng)建出來(lái)的是一個(gè) aspect 的以     .aj 結(jié)尾的類,并不是一個(gè)正經(jīng)的 Java 類,所以切面不到,也根本沒(méi)有對(duì)應(yīng)的 class 文件     如何正確使用Aspect 的.aj 類。
 

三、如何正確使用 Aspect 的 .aj 類

AspectJ,簡(jiǎn)稱 AJ  我自己說(shuō)的

AspectJ 其實(shí)也是 AOP 的一種實(shí)現(xiàn)技術(shù),功能類似于攔截器,在集成在 IntelliJ IDEA 開發(fā)工具里。在使用 IntelliJ IDEA 編寫 AspectJ 代碼之前需要本機(jī)先安裝 AspectJ 工具包。否則你的 .aj 類不能運(yùn)行,同時(shí)IDEA類顯示出來(lái)的 .aj 類,也是C的標(biāo)識(shí)

接下來(lái)我們就來(lái)聊聊關(guān)于這個(gè)東西怎么使用,別再被 .aj 騙了。

1. 安裝 AspectJ

在使用 AspectJ 之前,需要去官網(wǎng)下載一個(gè)安裝包,地址:https://www.eclipse.org/aspectj/downloads.php 如果官網(wǎng)下載的很慢,可以從我提供的源碼中獲取,也可以從其他途徑搜索下載 aspectj-1.9.4.jar

下載完成安裝;

  • 雙擊安裝
  • 命令安裝     java -jar aspectj-1.9.4.jar
  • 配置說(shuō)明:沒(méi)有配置,傻瓜式下一步就可以了
如何正確使用Aspect 的.aj 類  
  • 默認(rèn)配置安裝完成以后會(huì)在C盤創(chuàng)建出一個(gè)文件夾     C:\aspectj1.9,包括:bin、doc、lib等,后面我們就會(huì)使用到這些內(nèi)容。
 

2. AspectJ 插件

在專業(yè)版 IDEA 中開發(fā) AspectJ,需要安裝以下兩個(gè)插件:

  • Spring AOP/@AspectJ
  • AspectJ Support
如何正確使用Aspect 的.aj 類  
 

3. 添加依賴 aspectjrt.jar

開始之前需要在項(xiàng)目中添加 aspectjrt.jar 依賴,aspectjrt.jar 即 AspectJ 安裝目錄中lib目錄下的jar包。你可以復(fù)制到工程中引入,也可以直接引入

如何正確使用Aspect 的.aj 類  
  1. 在工程上鼠標(biāo)右鍵,點(diǎn)擊 Open Module Setting 打開     Project Structure
  2. 點(diǎn)擊 Libraries 選項(xiàng)卡,和上面的 + 號(hào),創(chuàng)建 New Project Library
  3. 選擇 C:\aspectj1.9\lib\aspectjrt.jar 路徑,點(diǎn)擊即可配置完成
 

4. 配置AspectJ編譯器

IDEA 默認(rèn)使用 javac 編譯器,這里需要配置 AspectJ 的編譯器 ajc,在 IDEA 中做相應(yīng)配置。

如何正確使用Aspect 的.aj 類  
  1. 打開 IDEA -> File  -> Settings 對(duì)話
  2. 選擇 Build,Execution,Deployment -> Compiler -> Java Compiler
  3. Use complier:選擇 Ajc
  4. 在 Path to aspectjtools.jar 里配置路徑     C:\aspectj1.9\lib\aspectjtools.jar
 

5. 案例測(cè)試

創(chuàng)建 Aspect 類

public aspect DoAspect {

    pointcut logPointcut():call(* ApiTest.hi(..));

    void around():call(void ApiTest.hi(..)){
        System.out.println("call 開始...");
        proceed();
        System.out.println("call 結(jié)束...");
    }

    before(): logPointcut(){
        System.out.println("方法執(zhí)行 before");
    }

    after(): logPointcut(){
        System.out.println("方法執(zhí)行 after");
    }

}
 

測(cè)試類

public class ApiTest {

    public void hi(){
        System.out.println("Hi Aspect");
    }

    public static void main(String[] args) {
        ApiTest apiTest = new ApiTest();
        apiTest.hi();
    }

}
 

測(cè)試結(jié)果

call 開始...
方法執(zhí)行 before
Hi Aspect
call 結(jié)束...
方法執(zhí)行 after

Process finished with exit code 0
 
  • 到這,才是一個(gè)關(guān)于 Aspect 類的正確打開方式,關(guān)于 Aspect 的使用也可以嘗試搞搞,此篇還只是關(guān)于此類切面寫法的一個(gè)入門。
 

四、總結(jié)

  • 你的代碼越粗獷、越豪放、越騷氣,幾乎你遇到的問(wèn)題也是越多的,可能就是因?yàn)闆](méi)有遵守一定的研發(fā)執(zhí)行規(guī)范,所以遇到的這些有點(diǎn)傻的問(wèn)題,幾乎會(huì)浪費(fèi)掉你一個(gè)上午或者一天。
  • 但有些時(shí)候如果你能認(rèn)真對(duì)待你弄出來(lái)的bug,深入分析下它是如何產(chǎn)生的,并把它復(fù)現(xiàn)出來(lái)一點(diǎn)點(diǎn)深入研究下,可能也會(huì)得到意想不到的收獲,也說(shuō)不定。所以凡是認(rèn)真,凡事沒(méi)有壞事。
  • 關(guān)于切面、關(guān)于源碼、關(guān)于開發(fā),可能并不應(yīng)該只注重于功能實(shí)現(xiàn),甚至有時(shí)候要想辦法逃離日復(fù)一日沒(méi)有成長(zhǎng)的工作內(nèi)容。多在那些有價(jià)值的技術(shù)上下功夫,那你的收獲也是最多的。


到此,相信大家對(duì)“如何正確使用Aspect 的.aj 類”有了更深的了解,不妨來(lái)實(shí)際操作一番吧!這里是億速云網(wǎng)站,更多相關(guān)內(nèi)容可以進(jìn)入相關(guān)頻道進(jìn)行查詢,關(guān)注我們,繼續(xù)學(xué)習(xí)!

向AI問(wèn)一下細(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