您好,登錄后才能下訂單哦!
今天就跟大家聊聊有關如何正確的使用Aspectj框架,可能很多人都不太了解,為了讓大家更加了解,小編給大家總結了以下內容,希望大家根據這篇文章可以有所收獲。
一 環境變量配置
CLASSPATH配置為:
.;d:\aspectj1.8\lib\aspectjrt.jar;D:\Program\Java\jdk1.8.0_162\lib\dt.jar;D:\Program\Java\jdk1.8.0_162\lib\tools.jar;
path要配置為:
d:\aspectj1.8\bin
二 代碼
1 JavaBean
Hello.java
package org.crazyit.app.service; public class Hello { // 定義一個簡單方法,模擬應用中的業務邏輯方法 public void foo() { System.out.println("執行Hello組件的foo()方法"); } // 定義一個addUser()方法,模擬應用中的添加用戶的方法 public int addUser(String name , String pass) { System.out.println("執行Hello組件的addUser添加用戶:" + name); return 20; } }
World.java
package org.crazyit.app.service; public class World { // 定義一個簡單方法,模擬應用中的業務邏輯方法 public void bar() { System.out.println("執行World組件的bar()方法"); } }
2 AOP
AuthAspect.java
package org.crazyit.app.aspect; public aspect AuthAspect { // 指定在執行org.crazyit.app.service包中任意類的、任意方法之前執行下面代碼塊 // 第一個星號表示返回值不限;第二個星號表示類名不限; // 第三個星號表示方法名不限;圓括號中..代表任意個數、類型不限的形參 before(): execution(* org.crazyit.app.service.*.*(..)) { System.out.println("模擬進行權限檢查..."); } }
LogAspect.java
package org.crazyit.app.aspect; public aspect LogAspect { // 定義一個PointCut,其名為logPointcut, // 該Pointcut代表了后面給出的切入點表達式,這樣可復用該切入點表達式 pointcut logPointcut() :execution(* org.crazyit.app.service.*.*(..)); after():logPointcut() { System.out.println("模擬記錄日志..."); } }
TxAspect.java
package org.crazyit.app.aspect; public aspect TxAspect { // 指定執行Hello.sayHello()方法時執行下面代碼塊 Object around():call(* org.crazyit.app.service.*.*(..)) { System.out.println("模擬開啟事務..."); // 回調原來的目標方法 Object rvt = proceed(); System.out.println("模擬結束事務..."); return rvt; } }
3 測試類
package lee; import org.crazyit.app.service.Hello; import org.crazyit.app.service.World; public class AspectJTest { public static void main(String[] args) { Hello hello = new Hello(); hello.foo(); hello.addUser("孫悟空" , "7788"); World world = new World(); world.bar(); } }
三 編譯
G:\test\AspectJQs>ajc -d . *.java
四 編譯后的結構
G:\test\AspectJQs>tree /f
卷 VirtualOS 的文件夾 PATH 列表
卷序列號為 8600-758F
G:.
│ AspectJTest.java
│ AuthAspect.java
│ Hello.java
│ LogAspect.java
│ TxAspect.java
│ World.java
│
├─lee
│ AspectJTest.class
│
└─org
└─crazyit
└─app
├─aspect
│ AuthAspect.class
│ LogAspect.class
│ TxAspect.class
│
└─service
Hello.class
World.class
五 運行
G:\test\AspectJQs>java lee.AspectJTest
模擬開啟事務...
模擬進行權限檢查...
執行Hello組件的foo()方法
模擬記錄日志...
模擬結束事務...
模擬開啟事務...
模擬進行權限檢查...
執行Hello組件的addUser添加用戶:孫悟空
模擬記錄日志...
模擬結束事務...
模擬開啟事務...
模擬進行權限檢查...
執行World組件的bar()方法
模擬記錄日志...
模擬結束事務...
看完上述內容,你們對如何正確的使用Aspectj框架有進一步的了解嗎?如果還想了解更多知識或者相關內容,請關注億速云行業資訊頻道,感謝大家的支持。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。