Aspectj框架實戰案例詳解
本文例項講述了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框架的java程式設計有所幫助。