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

Spring AOP 从原理到实战(结合事务彻底搞懂)

一、前言在后端开发中我们经常会遇到这种需求打日志统计接口耗时权限校验事务控制如果全部写在业务代码里会变成public void register() { log.info(开始执行); long start System.currentTimeMillis(); try { // 业务逻辑 } catch (Exception e) { log.error(异常); throw e; } log.info(耗时 (System.currentTimeMillis() - start)); } 问题代码重复业务逻辑被污染难维护二、什么是 AOPAOP 在不修改原代码的情况下在方法执行前后插入逻辑三、AOP 的核心思想结合事务理解在没有 AOP 时Controller → UserServiceImpl使用 AOP 后Controller → Proxy代理对象 → UserServiceImpl Proxy 做了什么方法前 → 加逻辑 方法后 → 加逻辑 异常时 → 加逻辑 这就是 AOP通过代理对象在方法前后织入增强逻辑四、AOP 与事务的关系重点Transactional ↓ Spring 识别 ↓ 生成 Proxy ↓ 方法执行前 → begin 方法执行后 → commit 异常 → rollback 结论事务本质就是AOP 的一个应用五、AOP 核心概念必须掌握1️⃣ 切面Aspect 你写的增强逻辑类Aspect Component public class LogAspect {}2️⃣ 切点Pointcut 指定拦截哪些方法execution(* com.xxx.service..*.*(..))3️⃣ 通知Advice 在什么时候执行注解含义Before方法前After方法后不管成功失败AfterReturning方法成功后AfterThrowing方法异常Around包一层最强六、AOP 实战最小可运行1️⃣ 引入依赖dependency groupIdorg.springframework.boot/groupId artifactIdspring-boot-starter-aop/artifactId /dependency2️⃣ 写切面Aspect Component public class LogAspect { Before(execution(* org.example.arkbackend.service..*.*(..))) public void before() { System.out.println(方法执行前); } }3️⃣ 测试效果方法执行前 执行注册逻辑七、Around核心能力Around(execution(* org.example.arkbackend.service..*.*(..))) public Object around(ProceedingJoinPoint pjp) throws Throwable { long start System.currentTimeMillis(); try { Object result pjp.proceed(); // 执行目标方法 long cost System.currentTimeMillis() - start; System.out.println(耗时 cost); return result; } catch (Throwable e) { long cost System.currentTimeMillis() - start; System.out.println(异常耗时 cost); throw e; } } 核心pjp.proceed(); 表示执行真正的业务方法八、切点表达式详解重点execution(* org.example.arkbackend.service..*.*(..))含义* → 任意返回值 service → 包路径 .. → 包含子包 * → 任意类 * → 任意方法 (..) → 任意参数 结论拦截 service 包及其子包下所有方法九、AOP 执行顺序面试重点多个切面会形成切面链Advisor Chain执行顺序由Order(1)控制数字越小越先执行推荐顺序日志外层 ↓ 事务内层 ↓ 方法 否则可能耗时统计不准确异常处理异常十、AOP 使用建议工程经验❌ 不要全部用 Around✅ 推荐用法场景用法打日志Before返回值处理AfterReturning异常日志AfterThrowing控制流程Around 原则能简单就不用复杂十一、常见坑必须知道❌ 切点路径写错service.*.* ❌ service..*.* ✅❌ 没加依赖spring-boot-starter-aop❌ 忘记 Component❌ 同类调用不生效同事务十二、总结AOP 本质是通过代理在方法执行前后织入增强逻辑事务就是基于 AOP 实现的典型应用在实际开发中应根据需求选择合适的通知类型而不是滥用 Around最后一句学会 AOP不是为了写注解而是为了把“重复逻辑抽离出来”

相关文章:

Spring AOP 从原理到实战(结合事务彻底搞懂)

一、前言在后端开发中,我们经常会遇到这种需求:打日志统计接口耗时权限校验事务控制如果全部写在业务代码里,会变成:public void register() {log.info("开始执行");long start System.currentTimeMillis();try {// 业…...

imFile下载管理器:如何实现高效的多协议下载管理?

imFile下载管理器:如何实现高效的多协议下载管理? 【免费下载链接】imfile-desktop A full-featured download manager. 项目地址: https://gitcode.com/gh_mirrors/im/imfile-desktop 在数字时代,文件下载已成为我们日常工作和学习中…...

Windows 11 LTSC 24H2一键恢复微软商店:完整实用指南

Windows 11 LTSC 24H2一键恢复微软商店:完整实用指南 【免费下载链接】LTSC-Add-MicrosoftStore Add Windows Store to Windows 11 24H2 LTSC 项目地址: https://gitcode.com/gh_mirrors/ltscad/LTSC-Add-MicrosoftStore 你是否正在使用Windows 11 LTSC 24H2…...

江科大STM32实战笔记精讲『上篇』

1. STM32入门实战基础 STM32作为嵌入式开发领域的明星产品,其强大的性能和丰富的外设资源使其成为工程师的首选。对于初学者来说,掌握STM32的核心外设配置是迈向嵌入式开发的第一步。本部分将重点介绍STM32最小系统搭建和开发环境配置。 要构建一个完整的…...

Phi-4-mini-flash-reasoning参数详解:Temperature 0.3 vs 0.6在解释深度上的差异

Phi-4-mini-flash-reasoning参数详解:Temperature 0.3 vs 0.6在解释深度上的差异 1. 模型概述 Phi-4-mini-flash-reasoning 是一款专注于复杂推理任务的轻量级文本生成模型。与通用大模型不同,它特别擅长处理需要多步推理和结构化分析的场景&#xff1…...

日志调试效率提升300%的秘密,深度集成Console、Output、Terminal与自定义Log Stream的全链路方案

更多请点击: https://intelliparadigm.com 第一章:日志调试效率提升300%的秘密,深度集成Console、Output、Terminal与自定义Log Stream的全链路方案 现代开发中,日志不再只是“打印信息”的附属品,而是贯穿诊断、监控…...

保姆级教程:手把手教你将屏厂初始化代码转换为RK3588 DTS配置(附避坑指南)

RK3588 MIPI屏幕初始化代码转换实战:从厂商原始代码到DTS配置的完整指南 每次拿到新屏幕的初始化代码时,那种面对密密麻麻十六进制数的茫然感我都记忆犹新。特别是当屏幕厂商提供的代码格式与RK3588平台要求的DTS配置格式不一致时,转换过程简…...

工业智能化趋势与CAD图检系统价值解析

一、工业智能化核心发展趋势 在新型工业化推进过程中,工业智能化已从单点技术应用迈向系统级融合赋能阶段,呈现出自主化、数智化、生态化三大核心演进方向。 (一)技术演进:从自动化智能迈向自主化智能 制造业智能化…...

从分辨力到稳定性:构建可靠测量系统的核心要素解析

1. 测量系统的基石:理解分辨力的本质 分辨力就像测量系统的"视力"——它决定了系统能否看清微小的变化。想象一下用普通尺子和游标卡尺测量同一根金属棒的长度差异:普通尺子可能只能识别1毫米的变化,而游标卡尺能捕捉0.02毫米的细微…...

3分钟专业解锁Mac NTFS读写:Free-NTFS-for-Mac深度实战指南

3分钟专业解锁Mac NTFS读写:Free-NTFS-for-Mac深度实战指南 【免费下载链接】Free-NTFS-for-Mac Nigate: An open-source NTFS utility for Mac. It supports all Mac models (Intel and Apple Silicon), providing full read-write access, mounting, and manageme…...

从零到一:构建数字世界的逻辑基石

1. 数字电路:现代科技的隐形骨架 第一次拆开计算器时,我盯着里面密密麻麻的黑色小方块发呆——这些就是数字电路芯片。它们像乐高积木一样,用最简单的0和1搭建出了整个数字世界。数字电路的本质,是用晶体管开关的两种状态&#xf…...

别再死记硬背DAX函数了!用Power BI做销售分析,这5个核心函数组合才是关键

从业务场景反推DAX函数组合:Power BI销售分析的5个核心武器 当你面对销售总监临时丢过来的需求——"明天早会给我一个能实时反映各区域销售趋势的动态看板"时,是否还在手忙脚乱地翻找DAX函数手册?真正高效的Power BI使用者从不会孤…...

从“伏安曲线”到“稳定放大”:三极管静态工作点设置的3个常见误区与避坑指南

从“伏安曲线”到“稳定放大”:三极管静态工作点设置的3个常见误区与避坑指南 当你第一次在面包板上搭建共射放大电路时,是否遇到过这样的困惑:明明按照教科书上的电路图连接,通电后却要么输出波形严重失真,要么三极管…...

DLSS Swapper:重新定义游戏性能优化的开源哲学

DLSS Swapper:重新定义游戏性能优化的开源哲学 【免费下载链接】dlss-swapper 项目地址: https://gitcode.com/GitHub_Trending/dl/dlss-swapper 当游戏性能优化不再是专业玩家的专利,当普通用户也能轻松掌控DLSS版本切换的奥秘,DLSS…...

从零玩转智能氛围灯:基于ESPHome与WS2812B的个性化灯光方案

1. 为什么选择ESPHome与WS2812B打造智能氛围灯? 如果你厌倦了传统智能灯只能调节亮度和颜色的单调功能,想要实现音乐律动、电影同步或者根据时间自动切换的沉浸式灯光效果,那么ESPHome搭配WS2812B灯带绝对是你的不二之选。我最初接触这个组合…...

Qwen3.5-2B模型在Keil5嵌入式开发中的实战应用

Qwen3.5-2B模型在Keil5嵌入式开发中的实战应用 1. 嵌入式开发的智能助手时代 作为一名嵌入式开发工程师,你是否经常遇到这样的场景:深夜调试代码时卡在一个寄存器配置问题上,翻遍手册却找不到明确答案;或者面对一个新的外设驱动…...

告别双闪屏!Android 12/13 启动画面SplashScreen全适配指南(含AndroidX库避坑实录)

Android 12/13启动画面深度适配指南:从双闪屏到完美体验 每次打开应用时那个恼人的双闪屏现象,正在悄悄消耗用户的耐心。当系统默认启动画面与应用自定义启动页接连闪现,这种割裂的体验已经成为Android 12设备上的普遍痛点。本文将带您深入理…...

反深度学习运动观察:软件测试从业者的专业审视

浪潮下的回响在当今软件工程领域,深度学习(Deep Learning)以其强大的数据驱动能力和在某些任务上的卓越表现,正以前所未有的速度渗透到包括软件测试在内的各个环节。从自动化测试脚本生成、缺陷预测到用户界面(UI&…...

光子计算测试挑战报告:面向软件测试从业者的专业视角解析

从电子到光子的范式转变当前,全球计算领域正经历一场深刻的范式转移,从以电子为信息载体的传统架构,迈向以光子为核心的新型计算体系。光子计算利用光波进行信息处理和传输,其超高速、低功耗、高并行性及抗电磁干扰的特性&#xf…...

5分钟极速转换:m4s-converter无损视频格式转换解决方案

5分钟极速转换:m4s-converter无损视频格式转换解决方案 【免费下载链接】m4s-converter 一个跨平台小工具,将bilibili缓存的m4s格式音视频文件合并成mp4 项目地址: https://gitcode.com/gh_mirrors/m4/m4s-converter 你是否遇到过这样的情况&…...

OBS多路RTMP推流插件完全指南:轻松实现多平台同步直播 [特殊字符]

OBS多路RTMP推流插件完全指南:轻松实现多平台同步直播 📺 【免费下载链接】obs-multi-rtmp OBS複数サイト同時配信プラグイン 项目地址: https://gitcode.com/gh_mirrors/ob/obs-multi-rtmp 想要同时在YouTube、Twitch、Bilibili等多个平台直播吗…...

为什么92%的开发者VSCode大模型配置失败?——资深架构师曝光4个隐藏配置断点

更多请点击: https://intelliparadigm.com 第一章:为什么92%的开发者VSCode大模型配置失败? VSCode 作为当前最主流的开发编辑器,其大模型插件(如 GitHub Copilot、Tabnine、CodeWhisperer 及本地 LLM 接入方案&#…...

避坑指南:海康MVS SDK与ROS2/OpenCV共存时的库冲突解决实录

工业视觉开发避坑指南:海康MVS SDK与ROS2/OpenCV的库冲突深度解决方案 当你在机器人导航项目中同时使用海康工业相机和ROS2时,可能会遇到一个令人头疼的问题:symbol lookup error: /lib/x86_64-linux-gnu/libpcl_io.so.1.12: undefined symbo…...

从‘等比例缩小’到‘等效缩减’:一文看懂芯片制程演进背后的材料与结构‘魔法’

从‘等比例缩小’到‘等效缩减’:芯片制程演进中的材料与结构革命 当第一台电子计算机ENIAC在1946年问世时,它重达27吨,功耗150千瓦,却只能完成每秒5000次加法运算。如今,一部智能手机的计算能力是它的数百万倍&#x…...

如何用SD-PPP插件实现Photoshop与AI绘图的无缝集成?

如何用SD-PPP插件实现Photoshop与AI绘图的无缝集成? 【免费下载链接】sd-ppp A Photoshop AI plugin 项目地址: https://gitcode.com/gh_mirrors/sd/sd-ppp 在数字创意工作流不断演进的今天,设计师面临着从概念到执行的高效转化挑战。传统Photosh…...

CodeForces-2179F Blackslex and Another RGB Walking 题解

设 disudis_udisu​ 为 1→u1\to u1→u 的最短距离。则若 (u,v)(u,v)(u,v) 存在,则 ∣disu−disv∣1|dis_u-dis_v|1∣disu​−disv​∣1。 证明:显然 ∣disu−disv∣≤1|dis_u-dis_v|\le 1∣disu​−disv​∣≤1,否则违背最短路性质。若 disu…...

高端咖啡机功率链路设计实战:精准、高效与智能控制的融合之道

在高端咖啡机朝着专业级萃取、多段控温与智能互联不断演进的今天,其内部的功率控制链路已不再是简单的开关单元,而是直接决定了冲泡品质、能耗表现与用户体验的核心。一条设计精良的功率链路,是咖啡机实现稳定水温、精准压力控制与快速响应的…...

保姆级教程:用安信可PB-02模组和PHY Mesh APP,三块板子搞定BLE Mesh智能灯组网

三块PB-02开发板玩转BLE Mesh智能灯:从零搭建到调色群控实战 去年工作室装修时,我偶然发现用三块开发板就能模拟智能家居的灯光系统。这种低成本方案不仅适合创客练手,还能直观理解Mesh网络的核心逻辑。下面就以安信可PB-02模组为例&#xff…...

Vivado FIR IP核配置避坑指南:从Coefficient Quantization到AXI-Stream接口,这些参数你真的设对了吗?

Vivado FIR IP核高阶配置实战:量化策略与AXI-Stream调试全解析 当你在Vivado中完成FIR滤波器的基本配置后,是否遇到过这些情况:仿真波形出现意外抖动、输出数据动态范围异常、资源利用率远超预期?这些问题的根源往往隐藏在IP核配置…...

从安防摄像头到网页直播:手把手教你用FFmpeg把RTSP流转成HLS(m3u8),解决浏览器播放难题

从安防摄像头到网页直播:FFmpeg实现RTSP转HLS全链路解决方案 当我们需要将企业园区、仓库或门店的安防监控画面集成到内部管理系统时,总会遇到一个技术瓶颈——现代浏览器无法直接播放摄像头输出的RTSP流。本文将彻底解决这个痛点,通过FFmpeg…...