1. 程式人生 > 程式設計 >Aspectj框架實戰案例詳解

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程式設計有所幫助。