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

相关文章

JVM 的类初始化机制

前言 当你在 Java 程序中new对象时,有没有考虑过 JVM 是如何把静态的字节码(byte code)转化为运行时对象的呢,这个问题看似简单,但清楚的同学相信也不会太多,这篇文章首先介绍 JVM 类初始化的机制,然后给出几个易出错的实例来分析,帮助大家更好理解这个知识点。 JVM 将字节码转化为运行时对象分为三个阶段,分别是:loading 、Linking、initialization

Spring Security 基于表达式的权限控制

前言 spring security 3.0已经可以使用spring el表达式来控制授权,允许在表达式中使用复杂的布尔逻辑来控制访问的权限。 常见的表达式 Spring Security可用表达式对象的基类是SecurityExpressionRoot。 表达式描述hasRole([role])用户拥有制定的角色时返回true (Spring security默认会带有ROLE_前缀),去

浅析Spring Security认证过程

类图 为了方便理解Spring Security认证流程,特意画了如下的类图,包含相关的核心认证类 概述 核心验证器 AuthenticationManager 该对象提供了认证方法的入口,接收一个Authentiaton对象作为参数; public interface AuthenticationManager {Authentication authenticate(Authenti

Spring Security--Architecture Overview

1 核心组件 这一节主要介绍一些在Spring Security中常见且核心的Java类,它们之间的依赖,构建起了整个框架。想要理解整个架构,最起码得对这些类眼熟。 1.1 SecurityContextHolder SecurityContextHolder用于存储安全上下文(security context)的信息。当前操作的用户是谁,该用户是否已经被认证,他拥有哪些角色权限…这些都被保

Spring Security基于数据库验证流程详解

Spring Security 校验流程图 相关解释说明(认真看哦) AbstractAuthenticationProcessingFilter 抽象类 /*** 调用 #requiresAuthentication(HttpServletRequest, HttpServletResponse) 决定是否需要进行验证操作。* 如果需要验证,则会调用 #attemptAuthentica

Spring Security 从入门到进阶系列教程

Spring Security 入门系列 《保护 Web 应用的安全》 《Spring-Security-入门(一):登录与退出》 《Spring-Security-入门(二):基于数据库验证》 《Spring-Security-入门(三):密码加密》 《Spring-Security-入门(四):自定义-Filter》 《Spring-Security-入门(五):在 Sprin

Java架构师知识体认识

源码分析 常用设计模式 Proxy代理模式Factory工厂模式Singleton单例模式Delegate委派模式Strategy策略模式Prototype原型模式Template模板模式 Spring5 beans 接口实例化代理Bean操作 Context Ioc容器设计原理及高级特性Aop设计原理Factorybean与Beanfactory Transaction 声明式事物

Java进阶13讲__第12讲_1/2

多线程、线程池 1.  线程概念 1.1  什么是线程 1.2  线程的好处 2.   创建线程的三种方式 注意事项 2.1  继承Thread类 2.1.1 认识  2.1.2  编码实现  package cn.hdc.oop10.Thread;import org.slf4j.Logger;import org.slf4j.LoggerFactory

csu 1446 Problem J Modified LCS (扩展欧几里得算法的简单应用)

这是一道扩展欧几里得算法的简单应用题,这题是在湖南多校训练赛中队友ac的一道题,在比赛之后请教了队友,然后自己把它a掉 这也是自己独自做扩展欧几里得算法的题目 题意:把题意转变下就变成了:求d1*x - d2*y = f2 - f1的解,很明显用exgcd来解 下面介绍一下exgcd的一些知识点:求ax + by = c的解 一、首先求ax + by = gcd(a,b)的解 这个

hdu2289(简单二分)

虽说是简单二分,但是我还是wa死了  题意:已知圆台的体积,求高度 首先要知道圆台体积怎么求:设上下底的半径分别为r1,r2,高为h,V = PI*(r1*r1+r1*r2+r2*r2)*h/3 然后以h进行二分 代码如下: #include<iostream>#include<algorithm>#include<cstring>#include<stack>#includ