基于注解的Spring的AOP代码实现试验

我们是基于AspectJ框架来实现Spring的AOP的:

步骤1: 添加jar包

XML 复制代码
<dependency>
    <groupId>aopalliance</groupId>
    <artifactId>aopalliance</artifactId>
    <version>1.0</version>
</dependency>
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-aspects</artifactId>
<version>5.0.6.RELEASE</version>
</dependency>

步骤2:写Spring的配置文件

把注解扫面打开,写接口和实现类,有main方法是测试类

步骤3:定义切面类,LoggerAspect

步骤4:spring的配置文件中,让@Before注解起作用

可以看到在指定的切入点,切入了切面类的方法,讲分离的日志代码和业务代码在运行时合起来了!

步骤5:继续完善切面类

@Before注解:

@Before和它注解的这个方法在AOP里叫:通知(advice),这个我们除了@Before这个叫前置通知(在切入目标方法执行之前执行)外,还有:

@After后置通知(在目标方法执行之后执行)

@AfterReturning返回通知(在目标方法返回结果之后执行)

@AfterThrowing异常通知(在目标方法跑出异常之后执行)

@Around环绕通知(围绕着方法执行)

@Before注解后的括号的内容叫AspectJ表达式,这里还可进一步使用通配符*

public int 换成 * : 任何修饰符和返回值类型

AopTestImpl换成*,表示cn.ybzy.springdemo包里的所有类

还可用两个点儿表示任意参数

很多个方法都是相同的切入点表达式,可以像提公因式样的提出来:

相关推荐
用户4682557459139 分钟前
Testcontainers 在 Windows Docker Desktop 上跑不通:协议层不兼容 + 4 种可行环境
java·后端
程序员小羊!30 分钟前
12.Java 多线程编程
java·开发语言
xuhaoyu_cpp_java36 分钟前
项目学习(三)代码生成器
java·经验分享·笔记·学习
乐观勇敢坚强的老彭37 分钟前
C++信息学奥赛lesson1
java·开发语言·c++
San813_LDD41 分钟前
[深度学习] 数据序列化格式对比:以日志级别配置为例
xml·java·前端
github_czy1 小时前
更加优雅的类型检查与传参---mcp源码分析
java·服务器·开发语言
专注_每天进步一点点1 小时前
IDEA中,Apifox Helper 的 2.0.15-243版本的插件 导出指定的接口,入参的中文名为空,描述为空
java·ide·intellij-idea
兰令水1 小时前
leecodecode【区间DP+树形DP】【2026.6.10打卡-java版本】
java·算法·leetcode
小刘|1 小时前
Spring WebFlux + AI 流式输出深度解析:Spring AI 与 LangChain4j 效果差异溯源
java·后端·spring
worilb1 小时前
Spring Cloud 学习与实践(8):Spring Cloud Gateway 统一入口、路由转发与双重跨域故障演练
学习·spring·spring cloud