Java练习(十九):编写代码,实现AOP的@Around操作 (两种写法)

2024-02-12 18:58

本文主要是介绍Java练习(十九):编写代码,实现AOP的@Around操作 (两种写法),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

目录

1. 要求

2. 涉及的知识点

3. 示例工程 (第一种方式)

3.1 maven的配置文件: pom.xml 

3.2 bean配置文件: bean_aop_around.xml

3.3 接口和类的代码

3.3.1 接口:UserService

3.3.2 实现接口的类:UserServiceImpl

3.3.3 AroundLog类:AroundLog

3.4 测试类 

4. 示例工程(第二种方式)

4.1 maven的配置文件: pom.xml 

4.2 bean配置文件: bean_aop_around2.xml

4.3 接口和类的代码

4.3.1 接口:UserService

4.3.2 实现接口的类:UserServiceImpl

4.3.3 AnnotationPointcut类:

4.4 测试类 


1. 要求

之前完成了通过@Before@After的方式,完成了对类UserServiceImpl中的search方法的aop操作 ,这里要求:通过@Aspect注解的方式实现对UserServiceImpl的aop的@Around操作!

前文:

Java练习(十):Spring应用之AOP的@Before, @After操作(简单工程示例)

2. 涉及的知识点

@Before, @After, @Around三者之前的关系:

@Before 是在所拦截方法执行之前执行一段逻辑。

@After 是在所拦截方法执行之后执行一段逻辑。

@Around 是可以同时在所拦截方法的前后执行一段逻辑。

简言之,@Around就包含了@Before和@After两个操作。

3. 示例工程 (第一种方式)

 

3.1 maven的配置文件: pom.xml 

<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0"xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd"><modelVersion>4.0.0</modelVersion><groupId>org.example</groupId><artifactId>MySpringAOPAround</artifactId><version>1.0-SNAPSHOT</version><properties><maven.compiler.source>8</maven.compiler.source><maven.compiler.target>8</maven.compiler.target></properties><dependencies><dependency><groupId>org.springframework</groupId><artifactId>spring-webmvc</artifactId><version>5.3.3</version></dependency><dependency><groupId>org.aspectj</groupId><artifactId>aspectjweaver</artifactId><version>1.9.4</version></dependency><dependency><groupId>dom4j</groupId><artifactId>dom4j</artifactId><version>1.6.1</version></dependency><dependency><groupId>junit</groupId><artifactId>junit</artifactId><version>4.12</version><scope>test</scope></dependency></dependencies></project>

3.2 bean配置文件: bean_aop_around.xml

<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"xmlns:context="http://www.springframework.org/schema/context"xmlns:aop="http://www.springframework.org/schema/aop"xmlns:p="http://www.springframework.org/schema/p"xmlns:c="http://www.springframework.org/schema/c"xsi:schemaLocation="http://www.springframework.org/schema/beanshttps://www.springframework.org/schema/beans/spring-beans.xsdhttp://www.springframework.org/schema/contexthttps://www.springframework.org/schema/context/spring-context.xsdhttp://www.springframework.org/schema/aophttp://www.springframework.org/schema/aop/spring-aop.xsd"><context:annotation-config/><!--注册bean--><bean id="userService" class="com.my.spring.aop.around.UserServiceImpl"/><bean id="aroundLog" class="com.my.spring.aop.around.AroundLog"/>
<!--    <bean id="beforeLog" class="com.my.spring.aop.around.BeforeLog"/>-->
<!--    <bean id="afterLog" class="com.my.spring.aop.around.AfterLog"/>--><!--aop的配置--><aop:config><!--切入点 expression:表达式匹配要执行的方法--><aop:pointcut id="pointcut" expression="execution(* com.my.spring.aop.around.UserServiceImpl.*(..))"/><aop:advisor advice-ref="aroundLog" pointcut-ref="pointcut"/>
<!--        <aop:advisor advice-ref="afterLog" pointcut-ref="pointcut"/>-->
<!--        <aop:advisor advice-ref="beforeLog" pointcut-ref="pointcut"/>--></aop:config></beans>

3.3 接口和类的代码

3.3.1 接口:UserService

package com.my.spring.aop.around;public interface UserService {public void add();public void delete();public void update();public void search();
}

3.3.2 实现接口的类:UserServiceImpl

package com.my.spring.aop.around;public class UserServiceImpl implements UserService{public void add() {System.out.println("增加用户");}public void delete() {System.out.println("删除用户");}public void update() {System.out.println("更新用户");}public void search() {System.out.println("查询用户");}
}

3.3.3 AroundLog类:AroundLog

package com.my.spring.aop.around;import org.aopalliance.intercept.MethodInterceptor;
import org.aopalliance.intercept.MethodInvocation;public class AroundLog implements MethodInterceptor {@Overridepublic Object invoke(MethodInvocation invocation) throws Throwable {String name = invocation.getMethod().getName();System.out.println("环绕通知: " + name + "方法即将开始!");// 调用目标对象的指定方法//真正调用目标方法Object result = invocation.proceed();System.out.println("环绕通知: " + name + "方法到此结束!");return result;}
}

3.4 测试类 

package com.my.spring.around.demo;import com.my.spring.aop.around.UserService;
import org.springframework.context.ApplicationContext;
import org.springframework.context.support.ClassPathXmlApplicationContext;public class MySpringAOPAroundTest {public static void main(String[] args) {ApplicationContext context = new ClassPathXmlApplicationContext("bean_aop_around.xml");UserService userService = (UserService) context.getBean("userService");userService.search();}}

输出结果:

环绕通知: search方法即将开始!
查询用户
环绕通知: search方法到此结束!

4. 示例工程(第二种方式)

用注解标签 @Aspect, @Around。

简言之,就是简化了bean配置文件里的内容,设置语句<aop:aspectj-autoproxy/>自动扫描,在工程中自动查找标签 @Aspect, @Around等。

4.1 maven的配置文件: pom.xml

同3.1,这里不赘述。

4.2 bean配置文件: bean_aop_around2.xml

<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"xmlns:context="http://www.springframework.org/schema/context"xmlns:aop="http://www.springframework.org/schema/aop"xmlns:p="http://www.springframework.org/schema/p"xmlns:c="http://www.springframework.org/schema/c"xsi:schemaLocation="http://www.springframework.org/schema/beanshttps://www.springframework.org/schema/beans/spring-beans.xsdhttp://www.springframework.org/schema/contexthttps://www.springframework.org/schema/context/spring-context.xsdhttp://www.springframework.org/schema/aophttp://www.springframework.org/schema/aop/spring-aop.xsd"><context:annotation-config/><!--注册bean--><bean id="annotationPointcut" class="com.my.spring.aop.around.AnnotationPointcut"/><bean id="userService2" class="com.my.spring.aop.around.UserServiceImpl"/><!-- 简化了bean配置文件里的内容,设置语句<aop:aspectj-autoproxy/>自动扫描 --><aop:aspectj-autoproxy/></beans>

4.3 接口和类的代码

4.3.1 接口:UserService

package com.my.spring.aop.around;public interface UserService {public void add();public void delete();public void update();public void search();
}

4.3.2 实现接口的类:UserServiceImpl

package com.my.spring.aop.around;public class UserServiceImpl implements UserService{public void add() {System.out.println("增加用户2");}public void delete() {System.out.println("删除用户2");}public void update() {System.out.println("更新用户2");}public void search() {System.out.println("查询用户2");}
}

4.3.3 AnnotationPointcut类:

类似于第一种方法中的AroundLog类,实现环绕效果,方法的调用。

使用注解@Aspect, @Around。

package com.my.spring.aop.around;// 如果自动扫描<aop:aspectj-autoproxy/>,那么程序肯定找标签
// 在整个工程里找标签,即如果包含多个类文件,多个@Aspect,程序都会找到并执行。
// 但真实的情况下,同一个方法,不会用多个@Aroundimport org.aspectj.lang.ProceedingJoinPoint;
import org.aspectj.lang.annotation.Around;
import org.aspectj.lang.annotation.Aspect;@Aspect
public class AnnotationPointcut {/*@Before("execution(*  com.my.demo.aop.UserServiceImpl.*(..))")public void before(){System.out.println("---------方法执行前---------");}@After("execution(* com.my.demo.aop.UserServiceImpl.*(..))")public void after(){System.out.println("---------方法执行后---------");}*/@Around("execution(* com.my.spring.aop.around.UserServiceImpl.*(..))")public void around(ProceedingJoinPoint jp) throws Throwable{System.out.println("~~~~~~~~~~~~~~~~Around方法执行前~~~~~~~~~~~~~~~~~~~~~");System.out.println("签名: "+jp.getSignature());Object proceed = jp.proceed(); //执行目标方法System.out.println("~~~~~~~~~~~~~~~~Around方法执行后~~~~~~~~~~~~~~~~~~~~~");}
}

4.4 测试类 

package com.my.spring.around.demo;import com.my.spring.aop.around.UserService;
import org.springframework.context.ApplicationContext;
import org.springframework.context.support.ClassPathXmlApplicationContext;public class MySpringAOPAroundTest2 {public static void main(String[] args) {ApplicationContext context = new ClassPathXmlApplicationContext("bean_aop_around2.xml");UserService userService = (UserService) context.getBean("userService2");userService.search();}
}

输出结果:

~~~~~~~~~~~~~~~~Around方法执行前~~~~~~~~~~~~~~~~~~~~~
签名: void com.my.spring.aop.around.UserService.search()
查询用户2
~~~~~~~~~~~~~~~~Around方法执行后~~~~~~~~~~~~~~~~~~~~~

这篇关于Java练习(十九):编写代码,实现AOP的@Around操作 (两种写法)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

springboot集成easypoi导出word换行处理过程

《springboot集成easypoi导出word换行处理过程》SpringBoot集成Easypoi导出Word时,换行符n失效显示为空格,解决方法包括生成段落或替换模板中n为回车,同时需确... 目录项目场景问题描述解决方案第一种:生成段落的方式第二种:替换模板的情况,换行符替换成回车总结项目场景s

SpringBoot集成redisson实现延时队列教程

《SpringBoot集成redisson实现延时队列教程》文章介绍了使用Redisson实现延迟队列的完整步骤,包括依赖导入、Redis配置、工具类封装、业务枚举定义、执行器实现、Bean创建、消费... 目录1、先给项目导入Redisson依赖2、配置redis3、创建 RedissonConfig 配

SpringBoot中@Value注入静态变量方式

《SpringBoot中@Value注入静态变量方式》SpringBoot中静态变量无法直接用@Value注入,需通过setter方法,@Value(${})从属性文件获取值,@Value(#{})用... 目录项目场景解决方案注解说明1、@Value("${}")使用示例2、@Value("#{}"php

SpringBoot分段处理List集合多线程批量插入数据方式

《SpringBoot分段处理List集合多线程批量插入数据方式》文章介绍如何处理大数据量List批量插入数据库的优化方案:通过拆分List并分配独立线程处理,结合Spring线程池与异步方法提升效率... 目录项目场景解决方案1.实体类2.Mapper3.spring容器注入线程池bejsan对象4.创建

线上Java OOM问题定位与解决方案超详细解析

《线上JavaOOM问题定位与解决方案超详细解析》OOM是JVM抛出的错误,表示内存分配失败,:本文主要介绍线上JavaOOM问题定位与解决方案的相关资料,文中通过代码介绍的非常详细,需要的朋... 目录一、OOM问题核心认知1.1 OOM定义与技术定位1.2 OOM常见类型及技术特征二、OOM问题定位工具

Python的Darts库实现时间序列预测

《Python的Darts库实现时间序列预测》Darts一个集统计、机器学习与深度学习模型于一体的Python时间序列预测库,本文主要介绍了Python的Darts库实现时间序列预测,感兴趣的可以了解... 目录目录一、什么是 Darts?二、安装与基本配置安装 Darts导入基础模块三、时间序列数据结构与

Python正则表达式匹配和替换的操作指南

《Python正则表达式匹配和替换的操作指南》正则表达式是处理文本的强大工具,Python通过re模块提供了完整的正则表达式功能,本文将通过代码示例详细介绍Python中的正则匹配和替换操作,需要的朋... 目录基础语法导入re模块基本元字符常用匹配方法1. re.match() - 从字符串开头匹配2.

基于 Cursor 开发 Spring Boot 项目详细攻略

《基于Cursor开发SpringBoot项目详细攻略》Cursor是集成GPT4、Claude3.5等LLM的VSCode类AI编程工具,支持SpringBoot项目开发全流程,涵盖环境配... 目录cursor是什么?基于 Cursor 开发 Spring Boot 项目完整指南1. 环境准备2. 创建

Python使用FastAPI实现大文件分片上传与断点续传功能

《Python使用FastAPI实现大文件分片上传与断点续传功能》大文件直传常遇到超时、网络抖动失败、失败后只能重传的问题,分片上传+断点续传可以把大文件拆成若干小块逐个上传,并在中断后从已完成分片继... 目录一、接口设计二、服务端实现(FastAPI)2.1 运行环境2.2 目录结构建议2.3 serv

C#实现千万数据秒级导入的代码

《C#实现千万数据秒级导入的代码》在实际开发中excel导入很常见,现代社会中很容易遇到大数据处理业务,所以本文我就给大家分享一下千万数据秒级导入怎么实现,文中有详细的代码示例供大家参考,需要的朋友可... 目录前言一、数据存储二、处理逻辑优化前代码处理逻辑优化后的代码总结前言在实际开发中excel导入很