当前位置: 首页 > news >正文

SpirngBoot核心思想之一AOP

简介:

AOP(Aspect-Oriented Programming,面向切面编程) 是一种用于解决软件系统中横切关注点的编程范式。在企业级开发中,很多非业务功能(如日志、事务、权限、安全等)需要在多个模块中执行,而这些功能与核心业务逻辑无关,却经常散布在业务代码中,导致代码冗余和难以维护。通过 AOP,可以将这些通用功能从业务逻辑中分离出来,形成独立的模块化“切面”,并动态地应用到业务逻辑中。Spring AOP 是 Spring 框架的重要组成部分,它通过切面编程为业务逻辑增加附加功能,而无需修改原始代码。

1. AOP 是什么?

AOP 的核心是处理 横切关注点(Cross-Cutting Concerns)。横切关注点指的是那些与业务逻辑无关、但却必须在多个业务逻辑中处理的功能。例如,日志记录、性能监控、安全性检查等,这些功能通常会跨越多个模块,如果不采用 AOP 机制,就必须在每个模块中硬编码这些功能。

AOP 的基本概念

为了深入理解 AOP,我们需要了解以下几个关键术语:

  • 切面(Aspect):切面是 AOP 的核心模块,代表一个横切关注点。它由切点和通知组成,通常是用于定义特定功能的模块,例如日志记录或事务管理。

  • 通知(Advice):通知是实际执行横切功能的代码块。它可以在目标方法执行之前、之后或异常抛出时运行。通知的类型包括:

    • @Before:在目标方法调用前执行。
    • @After:在目标方法调用后执行,无论是否成功。
    • @AfterReturning:在目标方法成功返回后执行。
    • @AfterThrowing:在目标方法抛出异常时执行。
    • @Around:包围目标方法的执行,可以在目标方法前后都执行,并且有能力改变返回值或终止方法执行。
  • 连接点(Join Point):连接点是在程序执行过程中,方法调用、异常抛出或属性访问等可插入切面的点。在 Spring AOP 中,连接点主要是指方法的执行。

  • 切点(Pointcut):切点定义了哪些连接点可以被切面拦截。切点表达式用于指定哪些方法应该应用通知。通过定义切点,开发者可以灵活地控制切面在哪些地方生效。

  • 织入(Weaving):织入是将切面应用到目标对象并创建代理对象的过程。Spring AOP 通过运行时动态代理来实现织入,这意味着切面代码是在程序运行时而不是编译时加入的。

2. 为什么使用 AOP?

在没有 AOP 的情况下,横切关注点(如日志、权限、安全等)通常会与业务逻辑紧密耦合,这样会导致:

  • 代码冗余:每个方法中可能都包含重复的日志、事务处理代码,导致大量冗余代码。

  • 维护困难:随着项目的复杂性增加,每当需要修改这些横切功能时,必须在多个模块中进行更新,容易出现遗漏或错误。

  • 耦合度高:业务逻辑与横切功能的紧密耦合降低了代码的灵活性和可扩展性,增加了维护和测试的难度。

通过 AOP,我们可以将这些横切功能模块化,分别管理它们,并通过声明方式将其动态应用到具体业务逻辑中。这不仅减少了代码冗余,还提高了代码的可维护性、可扩展性和可测试性。

3. Spring Boot 中如何实现 AOP?

Spring Boot 中 AOP 的实现主要依赖于 @Aspect 注解和通知方法。下面我们将详细介绍如何在 Spring Boot 中定义和使用切面。

3.1 项目配置

在 Spring Boot 中引入 AOP 非常简单,只需要在项目的 pom.xml 文件中加入 Spring AOP 依赖即可:

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

Spring Boot 会自动配置 AOP 并启用注解支持。

3.2 定义业务逻辑类

首先,创建一个简单的业务服务类 UserService,该类用于用户相关的操作。

import org.springframework.stereotype.Service;@Service
public class UserService {public void createUser(String name) {System.out.println("Creating user: " + name);}public void deleteUser(String name) {System.out.println("Deleting user: " + name);}
}

3.3 定义切面类

接下来,定义一个 LoggingAspect 切面类,在 UserService 的方法执行之前和之后记录日志。

import org.aspectj.lang.annotation.Aspect;
import org.aspectj.lang.annotation.Before;
import org.aspectj.lang.annotation.After;
import org.aspectj.lang.annotation.Pointcut;
import org.springframework.stereotype.Component;@Aspect
@Component
public class LoggingAspect {// 定义一个切点,匹配 UserService 中的所有方法@Pointcut("execution(* com.example.service.UserService.*(..))")public void userServiceMethods() {}// 在方法执行之前记录日志@Before("userServiceMethods()")public void logBeforeMethod() {System.out.println("Before method execution");}// 在方法执行之后记录日志@After("userServiceMethods()")public void logAfterMethod() {System.out.println("After method execution");}
}

在这个切面中,@Pointcut 定义了切点 userServiceMethods(),它匹配 UserService 中的所有方法。然后,使用 @Before 注解在方法执行之前记录日志,@After 注解在方法执行之后记录日志。

3.4 @Around 注解的使用

有时我们希望在方法执行前后都插入逻辑,并且能够控制目标方法的执行或修改其返回值,这时可以使用 @Around 注解。下面的例子演示了如何使用 @Around 通知来监控方法的执行时间。

import org.aspectj.lang.ProceedingJoinPoint;
import org.aspectj.lang.annotation.Around;
import org.aspectj.lang.annotation.Aspect;
import org.springframework.stereotype.Component;@Aspect
@Component
public class ExecutionTimeAspect {@Around("execution(* com.example.service.UserService.*(..))")public Object logExecutionTime(ProceedingJoinPoint joinPoint) throws Throwable {long startTime = System.currentTimeMillis();Object result = joinPoint.proceed();  // 执行目标方法long endTime = System.currentTimeMillis();System.out.println("Execution time of " + joinPoint.getSignature() + ": " + (endTime - startTime) + "ms");return result;}
}

在这个例子中,@Around 注解包围了 UserService 的方法执行,记录了方法的执行时间。joinPoint.proceed() 用于调用目标方法,并获取其返回值。

3.5 测试 AOP

编写一个 CommandLineRunner 来测试 UserService 的方法调用以及 AOP 的日志记录。

import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.boot.CommandLineRunner;
import org.springframework.stereotype.Component;@Component
public class AppRunner implements CommandLineRunner {@Autowiredprivate UserService userService;@Overridepublic void run(String... args) throws Exception {userService.createUser("Alice");userService.deleteUser("Bob");}
}

当你运行应用时,控制台将输出以下内容:

Before method execution
Creating user: Alice
After method execution
Before method execution
Deleting user: Bob
After method execution

如果使用了 @Around 注解监控执行时间,还会显示方法的执行时间。

4. AOP 的实际应用场景

AOP 在企业级应用中具有非常广泛的应用场景,常见的场景包括:

  • 日志记录:AOP 可以在不侵入业务代码的情况下,为系统中的所有方法添加统一的日志记录。
  • 事务管理:可以为特定的数据库操作自动启用事务,并在方法失败时回滚事务。
  • 安全检查:可以为某些方法自动添加权限校验逻辑,确保调用者具有访问权限。
  • 性能监控:可以记录方法的执行时间,识别系统中的性能瓶颈。
  • 缓存管理:可以在方法执行之前检查缓存,如果缓存中有结果,则直接返回,否则执行方法并缓存结果。

5. 总结

AOP 是 Spring 和 Spring Boot 中强大的工具,它通过将横切关注点与业务逻辑解耦,提高了代码的模块化、可维护性和复用性。在 Spring Boot 中,AOP 使用简单且灵活,能够轻松应用于日志、事务、安全等场景。

相关文章:

SpirngBoot核心思想之一AOP

简介&#xff1a; AOP&#xff08;Aspect-Oriented Programming&#xff0c;面向切面编程&#xff09; 是一种用于解决软件系统中横切关注点的编程范式。在企业级开发中&#xff0c;很多非业务功能&#xff08;如日志、事务、权限、安全等&#xff09;需要在多个模块中执行&am…...

足球预测推荐软件:百万数据阐述百年足球历史-大数据模型量化球员成就值

我开始创建这个模型是从梅西22世界杯夺冠第二天开始准备的&#xff0c;当时互联网上充斥了太多了个人情感的输出&#xff0c;有的人借题对C罗冷嘲热讽&#xff0c;有的人质疑梅西的阿根廷被安排夺冠不配超越马拉多纳做GOAT。作为一个从2002年开始看球的球迷&#xff0c;说实话有…...

AD中如何批量修改丝印的大小,节省layout时间

先选中一个元器件的丝印&#xff0c;然后右键&#xff0c;选择“查找相似项” 直接点击OK&#xff0c;这时会发现所有的丝印都会被选中 然后点击右上角的按键&#xff0c;修改其属性。...

Ps:堆栈

将多张类似的图像图层堆叠在一起形成图像堆栈 Stack&#xff0c;通过应用不同的堆栈模式&#xff0c;可以从这些图像中提取有用的信息或达到特定的视觉效果。 Photoshop 中的堆栈技术被广泛应用于摄影后期处理、科学研究、环境监测与分析等领域。 例如&#xff0c;它常用于减少…...

獨立IP和共用IP有什麼區別?

什麼是獨立IP&#xff1f; 獨立IP指的是一個IP地址專屬於一個用戶或設備。無論是網站、伺服器還是其他線上服務&#xff0c;獨立IP都意味著該IP地址不會與其他用戶或設備共用。獨立IP通常用於需要高安全性和穩定性的場景&#xff0c;比如企業網站、電子商務平臺和需要SSL證書的…...

枢纽云EKP数字门户模板上线!轻松复刻胖东来官网,实现数字化逆袭

数字化转型的浪潮中&#xff0c;胖东来凭借着其独特的企业文化和对员工福利的重视&#xff0c;走进了大众视野。近期&#xff0c;胖东来推出了“不开心假”等员工关怀&#xff0c;又一次引发了大众的广泛关注。这种关怀不仅仅提升了员工的幸福感&#xff0c;也间接的改善了顾客…...

从自动化到智能化:AI如何推动业务流程自动化

引言&#xff1a;从自动化到智能化的必然趋势 在当今数字化时代&#xff0c;企业为了提升效率、降低成本&#xff0c;纷纷采用自动化技术来简化重复性任务。然而&#xff0c;传统自动化仅限于标准化操作&#xff0c;无法应对复杂的决策和多变的市场环境。随着人工智能&#xff…...

Selenium与数据库结合:数据爬取与存储的技术实践

目录 一、Selenium与数据库结合的基础概念 1.1 Selenium简介 1.2 数据库简介 1.3 Selenium与数据库结合的优势 二、Selenium爬取数据的基本步骤 2.1 环境准备 2.2 编写爬虫代码 2.3 数据提取 2.4 异常处理 三、数据存储到数据库 3.1 数据库连接 3.2 数据存储 3.3 …...

在 Docker 中进入 Redis 容器后,可以通过以下方法查看 Redis 版本:

文章目录 1、info server2、redis-cli -v 1、info server [rootlocalhost ~]# docker exec -it spzx-redis redis-cli 127.0.0.1:6379> auth 123456 OK 127.0.0.1:6379> info server # Server redis_version:6.2.6 redis_git_sha1:00000000 redis_git_dirty:0 redis_bui…...

Windows 10 系统安装 FFmpeg 查看、转换、编辑音频文件

1、FFmpeg官网&#xff1a;FFmpeg 点击下载 可以选择下载full版本 下载之后解压到指定目录&#xff0c;在系统环境变量 Path 里面新增环境变量 打开CMD终端运行 ffmpeg -version 查看是否安装成功。 2、基本命令 查看音频基本信息 ffprobe 1.mp3 ##输出 [mp3 000002ab334405…...

反调试防护-API

IsDebuggerPresent() CheckRemoteDebuggerPresent() 其内部实际调用NtQueryInformationProcess() bool _stdcall ThreadCall() {while (true){BOOL pbDebuggerPresent FALSE;CheckRemoteDebuggerPresent(GetCurrentProcess(), &pbDebuggerPresent);if (pbDebuggerPres…...

【视频讲解】非参数重采样bootstrap逻辑回归Logistic应用及模型差异Python实现

全文链接&#xff1a;https://tecdat.cn/?p37759 分析师&#xff1a;Anting Li 本文将深入探讨逻辑回归在心脏病预测中的应用与优化。通过对加州大学欧文分校提供的心脏病数据集进行分析&#xff0c;我们将揭示逻辑回归模型的原理、实现过程以及其在实际应用中的优势和不足…...

Linux系统中命令wc

wc&#xff08;word count&#xff09;命令是Linux和Unix系统中用于计算字数的一个非常实用的工具。它可以统计文件的字节数、字数、行数等信息。默认情况下&#xff0c;wc命令会输出这三个统计值&#xff0c;但你也可以通过选项来指定只输出其中的某些值。 基本用法 wc [选项…...

redis集群部署

创建ConfigMap redis-cm.yaml apiVersion: v1 kind: ConfigMap metadata:name: redis-cluster data:update-node.sh: |#!/bin/shREDIS_NODES"/data/nodes.conf"sed -i -e "/myself/ s/[0-9]\{1,3\}\.[0-9]\{1,3\}\.[0-9]\{1,3\}\.[0-9]\{1,3\}/${POD_IP}/&quo…...

VUE条件树查询

看如下图所示的功能&#xff0c;是不是可高级了&#xff1f;什么&#xff0c;你没看懂&#xff1f;拜托双击放大看&#xff01; 是的&#xff0c;我最近消失了一段时间就是在研究这个玩意的实现&#xff0c;通过不懈努力与钻研并参考其他人员实现并加以改造&#xff0c;很好&am…...

vue框架学习 -- 日历控件 FullCalendar 使用总结

最近在项目中要实现日期排班的功能&#xff0c;正好要用到日历视图的控件&#xff0c;经过对比发现&#xff0c;vue 中 使用 FullCalendar 可以实现相关需求&#xff0c;下面对使用过程做一个总结。 一. 引入 FullCalendar 控件 package.json 中添加相关依赖 "dependen…...

[数据集][目标检测]猪数据集VOC-2856张

数据集格式&#xff1a;Pascal VOC格式(不包含分割的txt文件&#xff0c;仅仅包含jpg图片和对应的xml) 图片数量(jpg文件个数)&#xff1a;2856 标注数量(xml文件个数)&#xff1a;2856 标注类别数&#xff1a;1 标注类别名称:["pig"] 每个类别标注的框数&#xff1a…...

工业制造场景中的设备管理深度解析

在工业制造的广阔领域中&#xff0c;设备管理涵盖多个关键方面&#xff0c;对企业的高效生产和稳定运营起着举足轻重的作用。 一、设备运行管理 1.设备状态监测 实时监控设备的运行状态是确保生产顺利进行的重要环节。通过传感器和数据采集系统等先进技术&#xff0c;获取设备…...

OpenCV图像文件读写(3)统计多页图像文件中的页面数量函数imcount()的使用

操作系统&#xff1a;ubuntu22.04 OpenCV版本&#xff1a;OpenCV4.9 IDE:Visual Studio Code 编程语言&#xff1a;C11 算法描述 返回给定文件中的图像数量。 imcount 函数将返回多页图像中的页面数量&#xff0c;对于单页图像则返回 1。 函数原型 size_t cv::imcount (cons…...

【数据治理-构建数据标准体系】

构建数据标准体系分为六大主要步骤&#xff0c;分别是&#xff1a; 1、规划数据标准 2、开发数据标准 3、发布数据标准 4、执行数据标准 5、数据标准遵从检查 6、维护数据标准 1、规划数据标准 &#xff08;1&#xff09;数据标准的规划首先是在公司业务架构和数据架构的范围…...

使用docker在3台服务器上搭建基于redis 6.x的一主两从三台均是哨兵模式

一、环境及版本说明 如果服务器已经安装了docker,则忽略此步骤,如果没有安装,则可以按照一下方式安装: 1. 在线安装(有互联网环境): 请看我这篇文章 传送阵>> 点我查看 2. 离线安装(内网环境):请看我这篇文章 传送阵>> 点我查看 说明&#xff1a;假设每台服务器已…...

谷歌浏览器插件

项目中有时候会用到插件 sync-cookie-extension1.0.0&#xff1a;开发环境同步测试 cookie 至 localhost&#xff0c;便于本地请求服务携带 cookie 参考地址&#xff1a;https://juejin.cn/post/7139354571712757767 里面有源码下载下来&#xff0c;加在到扩展即可使用FeHelp…...

PPT|230页| 制造集团企业供应链端到端的数字化解决方案:从需求到结算的全链路业务闭环构建

制造业采购供应链管理是企业运营的核心环节&#xff0c;供应链协同管理在供应链上下游企业之间建立紧密的合作关系&#xff0c;通过信息共享、资源整合、业务协同等方式&#xff0c;实现供应链的全面管理和优化&#xff0c;提高供应链的效率和透明度&#xff0c;降低供应链的成…...

vue3 字体颜色设置的多种方式

在Vue 3中设置字体颜色可以通过多种方式实现&#xff0c;这取决于你是想在组件内部直接设置&#xff0c;还是在CSS/SCSS/LESS等样式文件中定义。以下是几种常见的方法&#xff1a; 1. 内联样式 你可以直接在模板中使用style绑定来设置字体颜色。 <template><div :s…...

React19源码系列之 事件插件系统

事件类别 事件类型 定义 文档 Event Event 接口表示在 EventTarget 上出现的事件。 Event - Web API | MDN UIEvent UIEvent 接口表示简单的用户界面事件。 UIEvent - Web API | MDN KeyboardEvent KeyboardEvent 对象描述了用户与键盘的交互。 KeyboardEvent - Web…...

《基于Apache Flink的流处理》笔记

思维导图 1-3 章 4-7章 8-11 章 参考资料 源码&#xff1a; https://github.com/streaming-with-flink 博客 https://flink.apache.org/bloghttps://www.ververica.com/blog 聚会及会议 https://flink-forward.orghttps://www.meetup.com/topics/apache-flink https://n…...

AI书签管理工具开发全记录(十九):嵌入资源处理

1.前言 &#x1f4dd; 在上一篇文章中&#xff0c;我们完成了书签的导入导出功能。本篇文章我们研究如何处理嵌入资源&#xff0c;方便后续将资源打包到一个可执行文件中。 2.embed介绍 &#x1f3af; Go 1.16 引入了革命性的 embed 包&#xff0c;彻底改变了静态资源管理的…...

为什么要创建 Vue 实例

核心原因:Vue 需要一个「控制中心」来驱动整个应用 你可以把 Vue 实例想象成你应用的**「大脑」或「引擎」。它负责协调模板、数据、逻辑和行为,将它们变成一个活的、可交互的应用**。没有这个实例,你的代码只是一堆静态的 HTML、JavaScript 变量和函数,无法「活」起来。 …...

「全栈技术解析」推客小程序系统开发:从架构设计到裂变增长的完整解决方案

在移动互联网营销竞争白热化的当下&#xff0c;推客小程序系统凭借其裂变传播、精准营销等特性&#xff0c;成为企业抢占市场的利器。本文将深度解析推客小程序系统开发的核心技术与实现路径&#xff0c;助力开发者打造具有市场竞争力的营销工具。​ 一、系统核心功能架构&…...

云原生周刊:k0s 成为 CNCF 沙箱项目

开源项目推荐 HAMi HAMi&#xff08;原名 k8s‑vGPU‑scheduler&#xff09;是一款 CNCF Sandbox 级别的开源 K8s 中间件&#xff0c;通过虚拟化 GPU/NPU 等异构设备并支持内存、计算核心时间片隔离及共享调度&#xff0c;为容器提供统一接口&#xff0c;实现细粒度资源配额…...