java aspect demo_AspectJ简单Demo

2024-03-06 16:40
文章标签 java 简单 demo aspect aspectj

本文主要是介绍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文件可以看出,字节码对应部分就已经被织入相应功能了。

这篇关于java aspect demo_AspectJ简单Demo的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/780696

相关文章

如何通过海康威视设备网络SDK进行Java二次开发摄像头车牌识别详解

《如何通过海康威视设备网络SDK进行Java二次开发摄像头车牌识别详解》:本文主要介绍如何通过海康威视设备网络SDK进行Java二次开发摄像头车牌识别的相关资料,描述了如何使用海康威视设备网络SD... 目录前言开发流程问题和解决方案dll库加载不到的问题老旧版本sdk不兼容的问题关键实现流程总结前言作为

redis群集简单部署过程

《redis群集简单部署过程》文章介绍了Redis,一个高性能的键值存储系统,其支持多种数据结构和命令,它还讨论了Redis的服务器端架构、数据存储和获取、协议和命令、高可用性方案、缓存机制以及监控和... 目录Redis介绍1. 基本概念2. 服务器端3. 存储和获取数据4. 协议和命令5. 高可用性6.

SpringBoot中使用 ThreadLocal 进行多线程上下文管理及注意事项小结

《SpringBoot中使用ThreadLocal进行多线程上下文管理及注意事项小结》本文详细介绍了ThreadLocal的原理、使用场景和示例代码,并在SpringBoot中使用ThreadLo... 目录前言技术积累1.什么是 ThreadLocal2. ThreadLocal 的原理2.1 线程隔离2

springboot将lib和jar分离的操作方法

《springboot将lib和jar分离的操作方法》本文介绍了如何通过优化pom.xml配置来减小SpringBoot项目的jar包大小,主要通过使用spring-boot-maven-plugin... 遇到一个问题,就是每次maven package或者maven install后target中的ja

Java中八大包装类举例详解(通俗易懂)

《Java中八大包装类举例详解(通俗易懂)》:本文主要介绍Java中的包装类,包括它们的作用、特点、用途以及如何进行装箱和拆箱,包装类还提供了许多实用方法,如转换、获取基本类型值、比较和类型检测,... 目录一、包装类(Wrapper Class)1、简要介绍2、包装类特点3、包装类用途二、装箱和拆箱1、装

如何利用Java获取当天的开始和结束时间

《如何利用Java获取当天的开始和结束时间》:本文主要介绍如何使用Java8的LocalDate和LocalDateTime类获取指定日期的开始和结束时间,展示了如何通过这些类进行日期和时间的处... 目录前言1. Java日期时间API概述2. 获取当天的开始和结束时间代码解析运行结果3. 总结前言在J

Java深度学习库DJL实现Python的NumPy方式

《Java深度学习库DJL实现Python的NumPy方式》本文介绍了DJL库的背景和基本功能,包括NDArray的创建、数学运算、数据获取和设置等,同时,还展示了如何使用NDArray进行数据预处理... 目录1 NDArray 的背景介绍1.1 架构2 JavaDJL使用2.1 安装DJL2.2 基本操

最长公共子序列问题的深度分析与Java实现方式

《最长公共子序列问题的深度分析与Java实现方式》本文详细介绍了最长公共子序列(LCS)问题,包括其概念、暴力解法、动态规划解法,并提供了Java代码实现,暴力解法虽然简单,但在大数据处理中效率较低,... 目录最长公共子序列问题概述问题理解与示例分析暴力解法思路与示例代码动态规划解法DP 表的构建与意义动

Java多线程父线程向子线程传值问题及解决

《Java多线程父线程向子线程传值问题及解决》文章总结了5种解决父子之间数据传递困扰的解决方案,包括ThreadLocal+TaskDecorator、UserUtils、CustomTaskDeco... 目录1 背景2 ThreadLocal+TaskDecorator3 RequestContextH

关于Spring @Bean 相同加载顺序不同结果不同的问题记录

《关于Spring@Bean相同加载顺序不同结果不同的问题记录》本文主要探讨了在Spring5.1.3.RELEASE版本下,当有两个全注解类定义相同类型的Bean时,由于加载顺序不同,最终生成的... 目录问题说明测试输出1测试输出2@Bean注解的BeanDefiChina编程nition加入时机总结问题说明