Aspectj框架實(shí)戰(zhàn)案例詳解
本文實(shí)例講述了Aspectj框架。分享給大家供大家參考,具體如下:
一 環(huán)境變量配置
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 { // 定義一個(gè)簡單方法,模擬應(yīng)用中的業(yè)務(wù)邏輯方法 public void foo() { System.out.println("執(zhí)行Hello組件的foo()方法"); } // 定義一個(gè)addUser()方法,模擬應(yīng)用中的添加用戶的方法 public int addUser(String name , String pass) { System.out.println("執(zhí)行Hello組件的addUser添加用戶:" + name); return 20; } }
World.java
package org.crazyit.app.service; public class World { // 定義一個(gè)簡單方法,模擬應(yīng)用中的業(yè)務(wù)邏輯方法 public void bar() { System.out.println("執(zhí)行World組件的bar()方法"); } }
2 AOP
AuthAspect.java
package org.crazyit.app.aspect; public aspect AuthAspect { // 指定在執(zhí)行org.crazyit.app.service包中任意類的、任意方法之前執(zhí)行下面代碼塊 // 第一個(gè)星號(hào)表示返回值不限;第二個(gè)星號(hào)表示類名不限; // 第三個(gè)星號(hào)表示方法名不限;圓括號(hào)中..代表任意個(gè)數(shù)、類型不限的形參 before(): execution(* org.crazyit.app.service.*.*(..)) { System.out.println("模擬進(jìn)行權(quán)限檢查..."); } }
LogAspect.java
package org.crazyit.app.aspect; public aspect LogAspect { // 定義一個(gè)PointCut,其名為logPointcut, // 該P(yáng)ointcut代表了后面給出的切入點(diǎn)表達(dá)式,這樣可復(fù)用該切入點(diǎn)表達(dá)式 pointcut logPointcut() :execution(* org.crazyit.app.service.*.*(..)); after():logPointcut() { System.out.println("模擬記錄日志..."); } }
TxAspect.java
package org.crazyit.app.aspect; public aspect TxAspect { // 指定執(zhí)行Hello.sayHello()方法時(shí)執(zhí)行下面代碼塊 Object around():call(* org.crazyit.app.service.*.*(..)) { System.out.println("模擬開啟事務(wù)..."); // 回調(diào)原來的目標(biāo)方法 Object rvt = proceed(); System.out.println("模擬結(jié)束事務(wù)..."); 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
四 編譯后的結(jié)構(gòu)
G:\test\AspectJQs>tree /f
卷 VirtualOS 的文件夾 PATH 列表
卷序列號(hào)為 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
五 運(yùn)行
G:\test\AspectJQs>java lee.AspectJTest
模擬開啟事務(wù)...
模擬進(jìn)行權(quán)限檢查...
執(zhí)行Hello組件的foo()方法
模擬記錄日志...
模擬結(jié)束事務(wù)...
模擬開啟事務(wù)...
模擬進(jìn)行權(quán)限檢查...
執(zhí)行Hello組件的addUser添加用戶:孫悟空
模擬記錄日志...
模擬結(jié)束事務(wù)...
模擬開啟事務(wù)...
模擬進(jìn)行權(quán)限檢查...
執(zhí)行World組件的bar()方法
模擬記錄日志...
模擬結(jié)束事務(wù)...
希望本文所述對(duì)大家基于Aspectj框架的java程序設(shè)計(jì)有所幫助。
- Android AOP框架AspectJ使用詳解
- java基于AspectJ(面向切面編程)編碼示例分享
- Spring使用AspectJ注解和XML配置實(shí)現(xiàn)AOP
- AndroidStudio 配置 AspectJ 環(huán)境實(shí)現(xiàn)AOP的方法
- 在Android項(xiàng)目中使用AspectJ的方法
- 分析java 中AspectJ切面執(zhí)行兩次的原因
- Android中使用AspectJ詳解
- AspectJ的基本用法
- Spring Aop之AspectJ注解配置實(shí)現(xiàn)日志管理的方法
- 詳解Spring Aop實(shí)例之AspectJ注解配置
- 詳解在Spring中如何使用AspectJ來實(shí)現(xiàn)AOP
- Spring用AspectJ開發(fā)AOP(基于Annotation)
相關(guān)文章
解決idea創(chuàng)建版本時(shí)只有Java21和Java17選項(xiàng)
你是否在使用IntelliJ?IDEA創(chuàng)建新項(xiàng)目時(shí)遇到了只有Java?21和Java?17的選項(xiàng)?別擔(dān)心,我們的指南將為你提供解決方案,通過簡單的步驟,你將能夠選擇你需要的任何Java版本,繼續(xù)閱讀,讓我們開始吧!2024-03-03Java中Vector、ArrayList、LinkedList的關(guān)系詳細(xì)解析
這篇文章主要介紹了Java中Vector、ArrayList、LinkedList的關(guān)系詳細(xì)解析,Vector和ArrayList底層均為Object數(shù)組,LinkedList底層是Node節(jié)點(diǎn),Vector是線程安全(底層方法均添加synchronized),ArrayList、LinkedList是線程不安全(無鎖),需要的朋友可以參考下2023-11-11Java中的==和equals()區(qū)別小結(jié)
在Java編程中,理解==操作符和equals()方法的區(qū)別是至關(guān)重要的,本文主要介紹了Java中的==和equals()區(qū)別,具有一定的參考價(jià)值,感興趣的可以了解一下2023-08-08mybatis plus自動(dòng)生成代碼tinyint(1)自動(dòng)轉(zhuǎn)換為Boolean的問題及解決
這篇文章主要介紹了mybatis plus自動(dòng)生成代碼tinyint(1)自動(dòng)轉(zhuǎn)換為Boolean的問題及解決方案,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-08-08