java aspect demo_AspectJ简单Demo

1.AspectJ介绍

AspectJ是一个面向切面的框架,是Eclipse旗下的一个项目,它扩展了Java语言。AspectJ定义了AOP语法,它有一个专门的编译器用来生成遵守Java字节编码规范的Class文件,下面会介绍2种方式用例展示。

2.原生方式

2.1 下载Jar包

Z

2.2 安装

进入AspectJ所在的jar包目录,CMD执行安装命令:

java -jar aspectj-1.9.6.jar

示例图如下:

Z

安装完成:

2Q==

2.3 环境配置

上一步安装完成AspectJ会提示要求配置环境变量;由于这里只是演示Demo,所以下面步骤采用直接带参数编译、运行即可;不怕麻烦的话自己也可以配置一下环境变量。

2.4 编写测试类、切面类

随便新建一个文件夹(我这里的路径是:“C:\Users\YYJ\Desktop\AspectJ_Test\src”),添加如下2个测试类,示图如下:

2Q==

Boss.java

public class Boss {

public static void main(String[] args) {

Boss boss = new Boss();

boss.meeting();

}

public void meeting() {

System.out.println("The boss is in a meeting");

}

}

BossAspect.java (AspectJ的特殊类)

public aspect BossAspect{

//定义切点

pointcut bossPoint() : execution(* meeting(..));

//前置通知,对切点增强

before() : bossPoint(){

System.out.println("Prepare something for metting");

}

}

2.5 利用ajc编译

由于偷懒没有配置AspectJ的环境变量,如果需要使用ajc命令,需要进入到AspectJ的安装目录的bin目录下执行

操作步骤:

CMD进入到AspectJ安装目录的bin目录下

cd C:\YYJ\Software\Aspectj1.9\bin

执行编译(需要指定类所在的文件目录):

ajc C:\Users\YYJ\Desktop\AspectJ_Test\src\*.java -injars C:\YYJ\Software\Aspectj1.9\lib\aspectjrt.jar

注释:

​1. C:\Users\YYJ\Desktop\AspectJ_Test\src\*.java 指定ajc需要编译哪些类,这里用的通配符

​2. -injars C:\YYJ\Software\Aspectj1.9\lib\aspectjrt.jar 没有配置环境变量,ajc编译时需要指定所需要依赖的jar,否则会报错:[error] classpath error: unable to find org.aspectj.lang.JoinPoint (check that aspectjrt.jar is in your classpath)

编译完成后如下如:

2Q==

2.6 运行Main方法

由于main方法写在了Boss类中,直接运行boss类即可;步骤如下:

切换到Boss.class文件所在目录下

cd C:\Users\YYJ\Desktop\AspectJ_Test\src

带依赖执行java命令:

java -classpath ".;C:\YYJ\Software\Aspectj1.9\lib\aspectjrt.jar" Boss

注意:-classpath ".;C:\YYJ\Software\Aspectj1.9\lib\aspectjrt.jar" 红色处不能少,否则会报一些依赖错误

控制台输入如下:

9k=

可见Boss类中的meeting方法得到了增强

3.Maven插件方式

3.1 Maven工程项目结构图:

9k=

3.2 pom.xml文件关键依赖:

org.aspectj

aspectjrt

1.9.6

org.codehaus.mojo

aspectj-maven-plugin

1.11

1.8

1.8

ignore

1.8

UTF-8

true

compile

test-compile

org.apache.maven.plugins

maven-compiler-plugin

3.7.0

1.8

1.8

UTF-8

3.3 Boss类

/**

* description: Boss类.

*/

public class Boss {

public static void main(String[] args) {

Boss boss = new Boss();

boss.meeting();

}

public void meeting() {

System.out.println("Boss开会!");

}

}

3.4 Secretary类

import org.aspectj.lang.JoinPoint;

import org.aspectj.lang.annotation.Aspect;

import org.aspectj.lang.annotation.Before;

import org.aspectj.lang.annotation.Pointcut;

/**

* description: Secretary类.

*/

@Aspect

public class Secretary {

/**

* description: 利用execution表达式定义切点

*/

@Pointcut("execution(* com.demo.Boss.meeting(..))")

public void pointCut(){

}

/**

* description: 前置通知

*/

@Before(value = "pointCut()")

public void doSomething(JoinPoint joinPoint){

System.out.println("通知员工时间、地点,告知大家Boss要开会");

}

}

3.5 测试:

为了方便/偷懒,main()方法直接写在了Boss类中,启动Boss类中的main方法,查看控制台输出如下图:

2Q==

利用IDEA自带的反编译,查看Boss.class、Secretary.class的反编译类信息:

Boss.class

import org.aspectj.lang.JoinPoint;

import org.aspectj.runtime.reflect.Factory;

public class Boss {

public Boss() {

}

public static void main(String[] args) {

Boss boss = new Boss();

boss.meeting();

}

public void meeting() {

JoinPoint var1 = Factory.makeJP(ajc$tjp_0, this, this);

Secretary.aspectOf().doSomething(var1);

System.out.println("Boss开会!");

}

static {

ajc$preClinit();

}

}

Secretary.class

import org.aspectj.lang.JoinPoint;

import org.aspectj.lang.NoAspectBoundException;

import org.aspectj.lang.annotation.Aspect;

import org.aspectj.lang.annotation.Before;

@Aspect

public class Secretary {

public Secretary() {

}

@Before("pointCut()")

public void doSomething(JoinPoint joinPoint) {

System.out.println("通知员工时间、地点,告知大家Boss要开会");

}

public static Secretary aspectOf() {

if (ajc$perSingletonInstance == null) {

throw new NoAspectBoundException("com.demo.Secretary", ajc$initFailureCause);

} else {

return ajc$perSingletonInstance;

}

}

public static boolean hasAspect() {

return ajc$perSingletonInstance != null;

}

static {

try {

ajc$postClinit();

} catch (Throwable var1) {

ajc$initFailureCause = var1;

}

}

}

由于Aspectj是静态织入,从反编译出来的class文件可以看出,字节码对应部分就已经被织入相应功能了。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Java Spring AOP (Aspect Oriented Programming) 是一种编程范式,它通过将应用的业务逻辑和系统关注点(如日志、事务管理等)分离,提高了代码的可维护性和复用性。下面是一个简单的Spring AOP切面(Aspect)的Demo示例: 首先,你需要在Spring配置文件中启用AOP支持,并定义一个切面(Aspect): ```xml <beans xmlns="http://www.springframework.org/schema/beans" xmlns:aspectj="http://www.springframework.org/schema/aop" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd http://www.springframework.org/schema/aop http://www.springframework.org/schema/aop/spring-aop.xsd"> <!-- 启用AOP --> <aop:aspectj-autoproxy/> <!-- 定义切面 --> <bean id="myAspect" class="com.example.MyAspect"> <!-- 配置通知(advice) --> <property name="beforeAdvice" ref="beforeAdvice"/> </bean> <!-- 定义通知 --> <bean id="beforeAdvice" class="com.example.BeforeAdvice"/> </beans> ``` 然后,创建一个`MyAspect`切面类,通常包含通知(advice),例如前置通知(BeforeAdvice): ```java import org.aspectj.lang.annotation.Aspect; import org.aspectj.lang.annotation.Before; @Aspect public class MyAspect { @Before("execution(* com.example.service.*.*(..))") public void beforeAdvice(JoinPoint joinPoint) { // 在方法执行前添加的操作,如日志记录 System.out.println("Method " + joinPoint.getSignature() + " is about to execute."); } } ``` 在这个例子中,`@Before`注解定义了一个前置通知,它将在`com.example.service`包下的所有方法执行前执行。 接下来,创建`BeforeAdvice`类,这是一个具体的通知实现: ```java public class BeforeAdvice { // 可能包含一些自定义逻辑,比如参数检查或资源获取 } ``` 相关问题--: 1. Spring AOP中的通知有哪些类型? 2. `@Aspect`注解在Spring AOP中的作用是什么? 3. 如何在Spring中配置切点(execution表达式)?
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值