使用Aspect来对访问方法进行预处理和后处理

2024-05-16 15:08

本文主要是介绍使用Aspect来对访问方法进行预处理和后处理,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

例子摘自李刚老师的《JavaEE企业应用实战(第四版)》661页

使用aspect中的@Around、@Before、@After、@AfterReturning,例子如下
切面类

package com.aspect;import java.util.Arrays;import org.aspectj.lang.JoinPoint;
import org.aspectj.lang.ProceedingJoinPoint;
import org.aspectj.lang.annotation.After;
import org.aspectj.lang.annotation.AfterReturning;
import org.aspectj.lang.annotation.Around;
import org.aspectj.lang.annotation.Aspect;
import org.aspectj.lang.annotation.Before;
@Aspect
public class FourAdviceTest {/*** 可以在执行方法之前和之后改变参数和返回值* @param joinPoint用于获取目标方法相关信息的参数* @return 最终的返回值* @throws Throwable*/@Around("execution(* com.service.*.*(..))")public Object processTx(ProceedingJoinPoint joinPoint) throws Throwable {System.out.println("Around增强:执行方法之前,模拟开始事物");Object[] args = joinPoint.getArgs();if(args != null && args.length > 0 && args[0].getClass() == String.class) {args[0] = "增加的前缀" + args[0];}Object rvt = joinPoint.proceed();System.out.println("Around增强:执行方法之后,模拟结束事物");if(rvt != null && rvt instanceof Integer) {rvt = (Integer)rvt * (Integer)rvt;}return rvt;}/*** 可以在执行方法之前对目标方法的参数进行判断* 通过抛出一个异常来阻断目标方法的访问* @param joinPoint*/@Before("execution(* com.service.*.*(..))")public void authority(JoinPoint joinPoint) {System.out.println("Before增强:模拟权限检查");System.out.println("Before增强:被织入增强处理的目标目标方法为:" + joinPoint.getSignature().getName());System.out.println("Before增强:目标方法的参数为:" + Arrays.toString(joinPoint.getArgs()));joinPoint.getArgs()[0] = "除了Around其他的都是是不可以修改目标方法的参数的";System.out.println("joinPoint.getArgs()[0]:"+joinPoint.getArgs()[0]);System.out.println("Before增强:目标方法的参数为:" + Arrays.toString(joinPoint.getArgs()));System.out.println("Before增强:被织入增强处理的目标对象为:" + joinPoint.getTarget());}/*** 可以在执行方法之后对目标方法的参数进行判断* @param joinPoint*/@After("execution(* com.service.*.*(..))")public void release(JoinPoint joinPoint) {System.out.println("After增强:模拟方法结束后的释放资源");System.out.println("After增强:被织入增强处理的目标方法为:" + joinPoint.getSignature().getName());System.out.println("After增强:目标方法的参数为:" + Arrays.toString(joinPoint.getArgs()));System.out.println("After增强:被织入增强处理的目标对象为" + joinPoint.getTarget());}/*** 与After的区别在于AfterReturning只有在方法执行成功的之后才会被织入,如果After和* AfterReturning同时存在于一个文件中,谁写在前面谁先运行* @param joinPoint* @param rvt方法的返回值*/@AfterReturning(pointcut="execution(* com.service.*.*(..))", returning="rvt")public void log(JoinPoint joinPoint, Object rvt) {System.out.println("AfterReturning增强:获取目标方法的返回值:" + rvt);System.out.println("AfterReturning增强:模拟日志功能");System.out.println("AfterReturning增强:获织入增强的目标方法为:" + joinPoint.getSignature().getName());System.out.println("AfterReturning增强:目标方法的参数为:" + Arrays.toString(joinPoint.getArgs()));System.out.println("AfterReturning增强:被织入增强处理的目标对象为:" + joinPoint.getTarget());}
}

Bean类

package com.service.impl;import org.springframework.stereotype.Component;import com.service.Hello;
@Component
public class HelloImpl implements Hello {@Overridepublic void hello() {// TODO Auto-generated method stubSystem.out.println("HelloImpl中的hello方法");}@Overridepublic int addUser(String name, String pass) {// TODO Auto-generated method stubSystem.out.println("执行Hello组件的addUser添加用户:" + name);if(name.length() < 3 || name.length() > 40) {throw new IllegalArgumentException("name的参数长度必须大于3小于10");}return 92;}
}

测试代码

        ApplicationContext applicationContext = new ClassPathXmlApplicationContext("beans.xml");HelloImpl helloImpl = applicationContext.getBean("helloImpl", HelloImpl.class);helloImpl.addUser("Slience", "12");

执行效果
值得注意的是@After和@AfterReturning或者有多个@After和@AfterReturning如果同时存在于一个文件里,他们的执行顺序是从上到下依次执行的;还有就是这里面只有@Around可以修改目标方法的接收参数和返回值,其他的都不可以修改;还有就是可以使用@AfterThrowing来对目标方法抛出的异常进行捕获和操作。

这篇关于使用Aspect来对访问方法进行预处理和后处理的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!


原文地址:
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.chinasem.cn/article/995254

相关文章

windows系统上如何进行maven安装和配置方式

《windows系统上如何进行maven安装和配置方式》:本文主要介绍windows系统上如何进行maven安装和配置方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不... 目录1. Maven 简介2. maven的下载与安装2.1 下载 Maven2.2 Maven安装2.

C/C++的OpenCV 进行图像梯度提取的几种实现

《C/C++的OpenCV进行图像梯度提取的几种实现》本文主要介绍了C/C++的OpenCV进行图像梯度提取的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的... 目录预www.chinasem.cn备知识1. 图像加载与预处理2. Sobel 算子计算 X 和 Y

MySQL的ALTER TABLE命令的使用解读

《MySQL的ALTERTABLE命令的使用解读》:本文主要介绍MySQL的ALTERTABLE命令的使用,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录1、查看所建表的编China编程码格式2、修改表的编码格式3、修改列队数据类型4、添加列5、修改列的位置5.1、把列

Python使用FFmpeg实现高效音频格式转换工具

《Python使用FFmpeg实现高效音频格式转换工具》在数字音频处理领域,音频格式转换是一项基础但至关重要的功能,本文主要为大家介绍了Python如何使用FFmpeg实现强大功能的图形化音频转换工具... 目录概述功能详解软件效果展示主界面布局转换过程截图完成提示开发步骤详解1. 环境准备2. 项目功能结

SpringBoot使用ffmpeg实现视频压缩

《SpringBoot使用ffmpeg实现视频压缩》FFmpeg是一个开源的跨平台多媒体处理工具集,用于录制,转换,编辑和流式传输音频和视频,本文将使用ffmpeg实现视频压缩功能,有需要的可以参考... 目录核心功能1.格式转换2.编解码3.音视频处理4.流媒体支持5.滤镜(Filter)安装配置linu

Redis中的Lettuce使用详解

《Redis中的Lettuce使用详解》Lettuce是一个高级的、线程安全的Redis客户端,用于与Redis数据库交互,Lettuce是一个功能强大、使用方便的Redis客户端,适用于各种规模的J... 目录简介特点连接池连接池特点连接池管理连接池优势连接池配置参数监控常用监控工具通过JMX监控通过Pr

MySQL启动报错:InnoDB表空间丢失问题及解决方法

《MySQL启动报错:InnoDB表空间丢失问题及解决方法》在启动MySQL时,遇到了InnoDB:Tablespace5975wasnotfound,该错误表明MySQL在启动过程中无法找到指定的s... 目录mysql 启动报错:InnoDB 表空间丢失问题及解决方法错误分析解决方案1. 启用 inno

apache的commons-pool2原理与使用实践记录

《apache的commons-pool2原理与使用实践记录》ApacheCommonsPool2是一个高效的对象池化框架,通过复用昂贵资源(如数据库连接、线程、网络连接)优化系统性能,这篇文章主... 目录一、核心原理与组件二、使用步骤详解(以数据库连接池为例)三、高级配置与优化四、典型应用场景五、注意事

使用Python实现Windows系统垃圾清理

《使用Python实现Windows系统垃圾清理》Windows自带的磁盘清理工具功能有限,无法深度清理各类垃圾文件,所以本文为大家介绍了如何使用Python+PyQt5开发一个Windows系统垃圾... 目录一、开发背景与工具概述1.1 为什么需要专业清理工具1.2 工具设计理念二、工具核心功能解析2.

Linux系统之stress-ng测压工具的使用

《Linux系统之stress-ng测压工具的使用》:本文主要介绍Linux系统之stress-ng测压工具的使用,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、理论1.stress工具简介与安装2.语法及参数3.具体安装二、实验1.运行8 cpu, 4 fo