基于注解的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包里的所有类

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

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

相关推荐
唐青枫4 分钟前
Java MyBatis 实战指南:XML 映射、动态 SQL 与数据访问层设计
java·mybatis
码语智行4 分钟前
MQTT 配置、依赖与使用说明
java·物联网·mt
_日拱一卒5 分钟前
LeetCode:39组合总和
java·算法·leetcode·职场和发展
郝学胜-神的一滴7 分钟前
力扣 662 :二叉树最大宽度
java·数据结构·c++·python·算法·leetcode·职场和发展
仙俊红8 分钟前
反射到底解决什么问题?
java·开发语言
小森林之主11 分钟前
凌晨3点的闹钟:分布式定时任务设计实战
java·redis·任务调度·cron·分布式定时任务
yaoxin52112313 分钟前
430. Java 日期时间 API - 时间计算 Temporal 包
java·前端·python
星马梦缘25 分钟前
数据库 第十三章 未完结版本
java·网络·数据库
程序猿乐锅26 分钟前
【JAVASE | 第十六篇】多线程
java·开发语言
做个文艺程序员27 分钟前
第01篇:Redis 从入门到上手:核心数据结构与 Java Spring Boot 实战详解
java·redis数据结构·redis入门·redis教程·java集成redis