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

Spring aop切面编程

Spring aop切面编程

  • 如何使用
  • 利用@AuditAction创建切入点

如何使用

@Aspect	// 1. 创建一个类,用@Aspect注解标记它,表明这是一个切面类。
@Component
public class LoggingAspect {// 2. 定义切点:在通知方法上,使用切点表达式来指定哪些方法将被拦截。// 切点表达式定义了你的通知将应用于哪些方法。@Pointcut("execution(* com.example.service.*.*(..))")public void serviceLayer() {}// 3. 定义通知:在切面类中,定义你的通知方法(前置通知、后置通知、返回后通知、异常通知、环绕通知),// 并使用相应的注解(@Before、@After、@AfterReturning、@AfterThrowing、@Around)标记。@Around("serviceLayer()")// ProceedingJoinPoint对象是JoinPoint的子接口,该对象只用在@Around的切面方法中public Object logExecutionTime(ProceedingJoinPoint joinPoint) throws Throwable {Object proceed = joinPoint.proceed(); // 执行目标方法return proceed;}
}

通知是根据其类型,在切点指定的连接点(Join point)的内容执行的特定时间点执行的,主要的通知类型及其执行时机:

  1. 前置通知(Before advice):在切点指定的方法执行之前执行。
  2. 后置通知(After advice):在切点指定的方法执行之后执行,无论方法执行成功还是异常结束。⚠️ after注解的通知方法会在finally里,一定会执行。
  3. 返回后通知(After-returning advice):在切点指定的方法成功执行之后执行。
  4. 异常后通知(After-throwing advice):在切点指定的方法抛出异常后执行。
  5. 环绕通知(Around advice):在切点指定的方法执行前后都可以执行,甚至可以决定是否执行目标方法。

如果切点已有,可以隐式定义切点:

@After(value = "execution(public * mapper.*.delete*(..))")	
// 切点:mapper目录下的所有的delete开头的public方法public Object logExecutionTime(ProceedingJoinPoint joinPoint) throws Throwable {Object proceed = joinPoint.proceed(); // 执行目标方法return proceed;}

利用@AuditAction创建切入点

@AuditAction 注解用于标记在需要进行审计日志记录的方法上,通过指定操作类型和目标表来描述该方法的行为。这种标记方式为 AOP 提供了一个“切入点”(Pointcut),使得 AOP 可以识别出哪些方法需要进行特定的处理。

假设有一个切面 ChangeLogAop,它通过 AOP 拦截所有标记了 @AuditAction 的方法,并根据注解中的信息执行相应的日志记录操作:

@Aspect
@Component
public class ChangeLogAop {// 拦截标记了 @AuditAction 注解的方法@After(value = "@annotation(auditAction)", argNames = "joinPoint,auditAction")public void doAudit(JoinPoint joinPoint, AuditAction auditAction) {// 根据 auditAction 中的信息(如操作类型和目标表)执行日志记录等操作}
}
http://www.lryc.cn/news/346633.html

相关文章:

  • 如何更好地使用Kafka? - 事先预防篇
  • 如何解决 IPA 打包过程中的 “Invalid Bundle Structure“ 错误
  • Vuex:Vue.js 的状态管理库
  • 【简单介绍下Sass】
  • IM 是什么?
  • 俄罗斯方块的代码实现
  • 出海企业哪种组网方案更省事?
  • triton编译学习
  • 源码知识付费系统,在线教学平台需要优化什么?
  • 后端常用技能:解决java项目前后端传输数据中文出现乱码、问号问题
  • SpringBoot中使用MongoDB
  • 【TS】入门
  • Apache ECharts
  • 超详细的胎教级Stable Diffusion使用教程(四)
  • 串口属性中的BM延时计时器问题
  • PyQt6--Python桌面开发(8.QPlainTextEdit纯文本控件)
  • Java | Leetcode Java题解之第83题删除排序链表中的重复元素
  • 重生奇迹mu再生宝石怎么用有什么用
  • pdf 文件版面分析--pdfplumber (python 文档解析提取)
  • PostgreSQL的学习心得和知识总结(一百四十三)|深入理解PostgreSQL数据库之Support event trigger for logoff
  • https免费证书获取
  • C语言 | Leetcode C语言题解之第74题搜索二维矩阵
  • 杰发科技AC7840——软件Sent_HAL39X
  • IOS 开发 - block 使用详解
  • BUU-[极客大挑战 2019]Http
  • 开发Web3 ETF的技术难点
  • 【K8s】Kubectl 常用命令梳理
  • 机器学习-监督学习
  • 搭建Docker私服镜像仓库Harbor
  • SpringBoot自定义初始化sql文件 支持多类型数据库