欢迎光临散文网 会员登陆 & 注册

SpringBootWeb事务管理 & AOP

2023-04-14 17:47 作者:苏喆i  | 我要投稿

目录

事务管理

AOP基础

AOP进阶

AOP案例

一、事务管理

1.事务回顾

概念:事务是一组操作的集合,它是一个不可分割的工作单位,这些操作 要么同时成功,要么同时失败

操作:

开启事务(一组操作开始前,开启事务):start transaction / begin ;

提交事务(这组操作全部成功后,提交事务):commit ;

回滚事务(中间任何一个操作出现异常,回滚事务):rollback ;

2.Spring事务管理

问题:即使程序运行抛出了异常,部门依然删除了,但是部门下的员工却没有删除,造成了数据的不一致。这样我们用到了@Transactional注解。

注解:@Transactional

位置:业务(service)层的方法上、类上、接口上

作用:将当前方法交给spring进行事务管理,方法执行前,开启事务;成功执行完毕,提交事务;出现异常,回滚事务

3.事务进阶

事务属性-回滚

rollbackFor

默认情况下,只有出现 RuntimeException 才回滚异常。rollbackFor属性用于控制出现何种异常类型,回滚事务。

事务属性-传播行为

propagation

事务传播行为:指的就是当一个事务方法被另一个事务方法调用时,这个事务方法应该如何进行事务控制。

只需要关注REQUIREDREQUIRES_NEW就可以了。

REQUIRED :大部分情况下都是用该传播行为即可。

REQUIRES_NEW :当我们不希望事务之间相互影响时,可以使用该传播行为。比如:下订单前需要记录日志,不论订单保存成功与否,都需要保证日志记录能够记录成功。

小结:

1.事务

2.Spring事务管理

@Transactional

3.事务属性

rollbackFor

propagation

二.AOP基础

1.AOP概述

AOP:Aspect Oriented Programming(面向切面编程、面向方面编程),其实就是面向特定方法编程。

场景:案例部分功能运行较慢,定位执行耗时较长的业务方法,此时需要统计每一个业务方法的执行耗时

实现:动态代理是面向切面编程最主流的实现。而SpringAOP是Spring框架的高级技术,旨在管理bean对象的过程中,主要通过底层的动态代理机制,对特定的方法进行编程。

2.AOP快速入门

Spring AOP快速入门:统计各个业务层方法执行耗时

①导入依赖:在pom.xml中导入AOP的依赖

②编写AOP程序:针对于特定方法根据业务需要进行编程

场景:

  • 记录操作日志

  • 权限控制

  • 事务管理

  • ……

优势:

  • 代码无侵入

  • 减少重复代码

  • 提高开发效率

  • 维护方便

3.AOP核心概念

  • 连接点:JoinPoint,可以被AOP控制的方法(暗含方法执行时的相关信息)

  • 通知:Advice,指哪些重复的逻辑,也就是共性功能(最终体现为一个方法)

  • 切入点:PointCut,匹配连接点的条件,通知仅会在切入点方法执行时被应用

  • 切面:Aspect,描述通知与切入点的对应关系(通知+切入点)

  • 目标对象:Target,通知所应用的对象

AOP执行流程

AOP执行流程

三、AOP进阶

1.通知类型

注意事项:

@Around环绕通知需要自己调用 ProceedingJoinPoint.proceed() 来让原始方法执行,其他通知不需要考虑目标方法执行

@Around环绕通知方法的返回值,必须指定为Object,来接收原始方法的返回值。


@PointCut

该注解的作用是将公共的切点表达式抽取出来,需要用到时引用该切点表达式即可。

小结:

通知类型

@Before(前置通知)

@After(后置通知)

@Around(环绕通知,重点)

@AfterReturning(返回后通知,了解)

@AfterThrowing(异常后通知,了解)

2.通知顺序

当有多个切面的切入点都匹配到了目标方法,目标方法运行时,多个通知方法都会被执行。

 执行顺序

1.不同切面类中,默认按照切面类的类名字母排序:

  • 目标方法前的通知方法:字母排名靠前的先执行

  • 目标方法后的通知方法:字母排名靠前的后执行

2.用@Order(数字)加载切面类上来控制顺序:

  • 目标方法前的通知方法:数字小的先执行

  • 目标方法后的通知方法:数字小的后执行

3.切入点表达式

切入点表达式@annotation

@annotation 切入点表达式,用于匹配标识有特定注解的方法。

首先自定义一个注解,用来标识方法

在方法上加入自定义注解@MyLog

小结:

1.execution(修饰符? 返回值 包名.类名.?方法名(参数) throws 异常?)

2.@annotation(注解全类名)

4.连接点

在Spring中用JoinPoint抽象了连接点,用它可以获得方法执行时的相关信息,如目标类名、方法名、方法参数等

  • 对于 @Around 通知,获取连接点信息只能使用  ProceedingJoinPoint

  • 对于其他四种通知,获取连接点信息只能使用 JoinPoint ,它是 ProceedingJoinPoint 的父类型

环绕通知@Around

四、AOP案例

将案例中 增、删、改 相关接口的操作日志记录到数据库表中。

操作日志:日志信息包含:操作人、操作时间、执行方法的全类名、执行方法名、方法运行时参数、返回值、方法执行时长。

思路分析:

  • 需要对所有业务类中的增、删、改 方法添加统一功能,使用 AOP 技术最为方便(@around 环绕通知)

  • 由于 增、删、改 方法名没有规律,可以自定义@Log注解完成目标方法匹配

步骤:

1.准备:

  • 在案例工程中引入AOP的起步依赖

  • 创建数据库表结构和实体类

2.编码:

  • 自定义注解@Log

  • 定义切面类,完成记录操作日志的逻辑

获取当前登录用户:

获取request对象,从请求头中获取到jwt令牌,解析令牌获取出当前用户的id


1.引入AOP的起步依赖:

2.创建数据库:

3.实体类(pojo):

4.mapper接口(mapper):

5.自定义注解@Log(anno):

6.切面类(aop):

7.在DeptController和EmpController中的增删改方法中加入注解@Log即可

8.启动服务,进行测试

SpringBootWeb事务管理 & AOP的评论 (共 条)

分享到微博请遵守国家法律