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

相关文章

使用Python实现IP地址和端口状态检测与监控

《使用Python实现IP地址和端口状态检测与监控》在网络运维和服务器管理中,IP地址和端口的可用性监控是保障业务连续性的基础需求,本文将带你用Python从零打造一个高可用IP监控系统,感兴趣的小伙... 目录概述:为什么需要IP监控系统使用步骤说明1. 环境准备2. 系统部署3. 核心功能配置系统效果展

Java 实用工具类Spring 的 AnnotationUtils详解

《Java实用工具类Spring的AnnotationUtils详解》Spring框架提供了一个强大的注解工具类org.springframework.core.annotation.Annot... 目录前言一、AnnotationUtils 的常用方法二、常见应用场景三、与 JDK 原生注解 API 的

Java controller接口出入参时间序列化转换操作方法(两种)

《Javacontroller接口出入参时间序列化转换操作方法(两种)》:本文主要介绍Javacontroller接口出入参时间序列化转换操作方法,本文给大家列举两种简单方法,感兴趣的朋友一起看... 目录方式一、使用注解方式二、统一配置场景:在controller编写的接口,在前后端交互过程中一般都会涉及

Java中的StringBuilder之如何高效构建字符串

《Java中的StringBuilder之如何高效构建字符串》本文将深入浅出地介绍StringBuilder的使用方法、性能优势以及相关字符串处理技术,结合代码示例帮助读者更好地理解和应用,希望对大家... 目录关键点什么是 StringBuilder?为什么需要 StringBuilder?如何使用 St

Python实现微信自动锁定工具

《Python实现微信自动锁定工具》在数字化办公时代,微信已成为职场沟通的重要工具,但临时离开时忘记锁屏可能导致敏感信息泄露,下面我们就来看看如何使用Python打造一个微信自动锁定工具吧... 目录引言:当微信隐私遇到自动化守护效果展示核心功能全景图技术亮点深度解析1. 无操作检测引擎2. 微信路径智能获

使用Java将各种数据写入Excel表格的操作示例

《使用Java将各种数据写入Excel表格的操作示例》在数据处理与管理领域,Excel凭借其强大的功能和广泛的应用,成为了数据存储与展示的重要工具,在Java开发过程中,常常需要将不同类型的数据,本文... 目录前言安装免费Java库1. 写入文本、或数值到 Excel单元格2. 写入数组到 Excel表格

Java并发编程之如何优雅关闭钩子Shutdown Hook

《Java并发编程之如何优雅关闭钩子ShutdownHook》这篇文章主要为大家详细介绍了Java如何实现优雅关闭钩子ShutdownHook,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起... 目录关闭钩子简介关闭钩子应用场景数据库连接实战演示使用关闭钩子的注意事项开源框架中的关闭钩子机制1.

Python中pywin32 常用窗口操作的实现

《Python中pywin32常用窗口操作的实现》本文主要介绍了Python中pywin32常用窗口操作的实现,pywin32主要的作用是供Python开发者快速调用WindowsAPI的一个... 目录获取窗口句柄获取最前端窗口句柄获取指定坐标处的窗口根据窗口的完整标题匹配获取句柄根据窗口的类别匹配获取句

Maven中引入 springboot 相关依赖的方式(最新推荐)

《Maven中引入springboot相关依赖的方式(最新推荐)》:本文主要介绍Maven中引入springboot相关依赖的方式(最新推荐),本文给大家介绍的非常详细,对大家的学习或工作具有... 目录Maven中引入 springboot 相关依赖的方式1. 不使用版本管理(不推荐)2、使用版本管理(推

Java 中的 @SneakyThrows 注解使用方法(简化异常处理的利与弊)

《Java中的@SneakyThrows注解使用方法(简化异常处理的利与弊)》为了简化异常处理,Lombok提供了一个强大的注解@SneakyThrows,本文将详细介绍@SneakyThro... 目录1. @SneakyThrows 简介 1.1 什么是 Lombok?2. @SneakyThrows