Spring之AOP面向切面编程实现(一)

2024-09-06 16:38

本文主要是介绍Spring之AOP面向切面编程实现(一),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

实现方式:基于配置XML和基于注解实现。


场景:一个手机进货系统,一旦要进货(或出货),要提前记录进货时间,进货完毕后,还要提醒其它人进行验货。

分析:3步走,1,操作进货(或出货)的方法的时候,先记录当前的时间,完毕后,提醒其他人验货。为了不使代码变得冗余,采用aop的策略实现。

基于配置实现

进货出货的接口:

IPhoneService.java

public interface IPhoneService {public void salePhone();public void buyPhone();
}

进货出货的接口实现:

PhoneServiceImpl.java

public class PhoneServiceImpl implements IPhoneService{@Overridepublic void salePhone() {System.out.println("销售iPhone系列手机");}@Overridepublic void buyPhone() {System.out.println("进货iPhone系列手机");//throw new RuntimeException();//模拟出现异常使用}}

切入的事件处理:

LogAdvice.java

import org.aspectj.lang.JoinPoint;public class LogAdvice {public void before(JoinPoint jp){System.out.println("1.在" + jp.getSignature().getName() + "执行之前切入的内容"+",记录进出货时间");}public void afterMethod(JoinPoint jp){System.out.println("2.在" + jp.getSignature().getName() + "执行之后切入的内容"+",提醒其他人验货");}public void afterThrow(JoinPoint jp,RuntimeException re){System.out.println("3.方法" + jp.getSignature().getName() + "执行过程中,抛出了异常");}}

spring配置(切面,切点,切入事件)

applicationContext.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:aop="http://www.springframework.org/schema/aop"xsi:schemaLocation="http://www.springframework.org/schema/aop http://www.springframework.org/schema/aop/spring-aop-3.1.xsdhttp://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-3.1.xsd"><bean id="phoneService" class="com.ysdit.spring2.service.PhoneServiceImpl"></bean><!-- 增强处理,切入的内容 --><bean id="logAdvice" class="com.ysdit.spring2.service.aop.LogAdvice"></bean><aop:config><!-- 地点,切入的位置,该包下的任何方法的任何返回值,任何参数。都切入 --><aop:pointcut expression="execution(* com.ysdit.spring2.service.*.*(..))" id="phonePoint"/><aop:aspect ref="logAdvice" id="ap1"><!-- 时间,非功能需求代码切入的时间 --><aop:after-returning method="afterMethod" pointcut-ref="phonePoint"/></aop:aspect><aop:aspect ref="logAdvice" id="ap2"><aop:before method="before" pointcut-ref="phonePoint"/></aop:aspect><aop:aspect ref="logAdvice" id="ap3"><aop:after-throwing method="afterThrow" pointcut-ref="phonePoint" throwing="re"/></aop:aspect></aop:config></beans>

测试类:

AopTest.java

import com.ysdit.spring2.service.IPhoneService;
import org.springframework.context.ApplicationContext;
import org.springframework.context.support.ClassPathXmlApplicationContext;public class AopTest {/*** @param args*/public static void main(String[] args) {ApplicationContext ctx = new ClassPathXmlApplicationContext("applicationContext.xml");IPhoneService phoneService = (IPhoneService) ctx.getBean("phoneService");phoneService.buyPhone();}}

执行购手机的方法,控制台打印如下:

这里写图片描述

执行卖手机的方法,控制台打印如下:

这里写图片描述

模拟执行卖手机的方法,出现异常,控制台打印如下:

这里写图片描述

发生异常,程序依旧能通知我们出现了异常,能通知及时处理.

百度云云盘分享(配置实现):http://pan.baidu.com/s/1dFG46w5


基于注解实现

修改:
applicationContext.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:aop="http://www.springframework.org/schema/aop"xsi:schemaLocation="http://www.springframework.org/schema/aop http://www.springframework.org/schema/aop/spring-aop-3.1.xsdhttp://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-3.1.xsd"><!--告诉spring要使用aop注解 --><aop:aspectj-autoproxy/><bean id="phoneService" class="com.ysdit.spring2.service.PhoneServiceImpl"></bean><!-- 增强处理,切入的内容 --><bean id="logAdvice" class="com.ysdit.spring2.service.aop.LogAdvice"></bean></beans>

修改:
LogAdvice.java

import org.aspectj.lang.JoinPoint;
import org.aspectj.lang.annotation.*;@Aspect
public class LogAdvice {@Pointcut("execution(* com.ysdit.spring2.service.*.*(..))")//这样是为了,实现切入点的重用public void pointcut(){}@Before("pointcut()")public void before(JoinPoint jp){System.out.println("1.在" + jp.getSignature().getName() + "执行之前切入的内容"+",记录进出货时间");}@After("pointcut()")public void afterMethod(JoinPoint jp){System.out.println("2.在" + jp.getSignature().getName() + "执行之后切入的内容"+",提醒其他人验货");}@AfterThrowing("pointcut()")public void afterThrow(JoinPoint jp){System.out.println("3.方法" + jp.getSignature().getName() + "执行过程中,抛出了异常");}}

执行购手机的方法,控制台打印如下:

这里写图片描述

执行卖手机的方法,控制台打印如下:

这里写图片描述

模拟执行卖手机的方法,出现异常,控制台打印如下:

这里写图片描述

发生异常,程序依旧能通知我们出现了异常,能通知及时处理.

百度云盘链接(注解实现):http://pan.baidu.com/s/1nu5OC8h


对于spring-boot 启用aop注解

1.添加依赖

<dependency>    <groupId>org.springframework.boot</groupId>    <artifactId>spring-boot-starter-aop</artifactId>
</dependency>

2.开启注解

spring.aop.auto=true

完成

这篇关于Spring之AOP面向切面编程实现(一)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

Java对异常的认识与异常的处理小结

《Java对异常的认识与异常的处理小结》Java程序在运行时可能出现的错误或非正常情况称为异常,下面给大家介绍Java对异常的认识与异常的处理,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参... 目录一、认识异常与异常类型。二、异常的处理三、总结 一、认识异常与异常类型。(1)简单定义-什么是

SpringBoot项目配置logback-spring.xml屏蔽特定路径的日志

《SpringBoot项目配置logback-spring.xml屏蔽特定路径的日志》在SpringBoot项目中,使用logback-spring.xml配置屏蔽特定路径的日志有两种常用方式,文中的... 目录方案一:基础配置(直接关闭目标路径日志)方案二:结合 Spring Profile 按环境屏蔽关

Python实现精准提取 PDF中的文本,表格与图片

《Python实现精准提取PDF中的文本,表格与图片》在实际的系统开发中,处理PDF文件不仅限于读取整页文本,还有提取文档中的表格数据,图片或特定区域的内容,下面我们来看看如何使用Python实... 目录安装 python 库提取 PDF 文本内容:获取整页文本与指定区域内容获取页面上的所有文本内容获取

基于Python实现一个Windows Tree命令工具

《基于Python实现一个WindowsTree命令工具》今天想要在Windows平台的CMD命令终端窗口中使用像Linux下的tree命令,打印一下目录结构层级树,然而还真有tree命令,但是发现... 目录引言实现代码使用说明可用选项示例用法功能特点添加到环境变量方法一:创建批处理文件并添加到PATH1

Java使用HttpClient实现图片下载与本地保存功能

《Java使用HttpClient实现图片下载与本地保存功能》在当今数字化时代,网络资源的获取与处理已成为软件开发中的常见需求,其中,图片作为网络上最常见的资源之一,其下载与保存功能在许多应用场景中都... 目录引言一、Apache HttpClient简介二、技术栈与环境准备三、实现图片下载与保存功能1.

canal实现mysql数据同步的详细过程

《canal实现mysql数据同步的详细过程》:本文主要介绍canal实现mysql数据同步的详细过程,本文通过实例图文相结合给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的... 目录1、canal下载2、mysql同步用户创建和授权3、canal admin安装和启动4、canal

SpringBoot排查和解决JSON解析错误(400 Bad Request)的方法

《SpringBoot排查和解决JSON解析错误(400BadRequest)的方法》在开发SpringBootRESTfulAPI时,客户端与服务端的数据交互通常使用JSON格式,然而,JSON... 目录问题背景1. 问题描述2. 错误分析解决方案1. 手动重新输入jsON2. 使用工具清理JSON3.

java中long的一些常见用法

《java中long的一些常见用法》在Java中,long是一种基本数据类型,用于表示长整型数值,接下来通过本文给大家介绍java中long的一些常见用法,感兴趣的朋友一起看看吧... 在Java中,long是一种基本数据类型,用于表示长整型数值。它的取值范围比int更大,从-922337203685477

Nexus安装和启动的实现教程

《Nexus安装和启动的实现教程》:本文主要介绍Nexus安装和启动的实现教程,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、Nexus下载二、Nexus安装和启动三、关闭Nexus总结一、Nexus下载官方下载链接:DownloadWindows系统根

java Long 与long之间的转换流程

《javaLong与long之间的转换流程》Long类提供了一些方法,用于在long和其他数据类型(如String)之间进行转换,本文将详细介绍如何在Java中实现Long和long之间的转换,感... 目录概述流程步骤1:将long转换为Long对象步骤2:将Longhttp://www.cppcns.c