2025年springboot aop日志管理(springboot aop操作日志)

springboot aop日志管理(springboot aop操作日志)目录 前言 思路 技术储备 java 注解 Spring AOP 实现步骤 定义日志类 定义一个切面类编写切面 切面环绕通知 cotroller 配置 附录 一个 bug 先看需求 最近项目有个模块要求可以记录人员的每一步操作 并且后台可以查看记录 设计图如下 基于需求 思考了下 首先 每个模块需要可配置化 且需要灵活配置到各个类和方法上 其次 需要一个统一的模块去处理日志相关的东西

大家好,我是讯享网,很高兴认识大家。



目录

前言

思路

技术储备

java注解

Spring AOP

实现步骤

定义日志类

定义一个切面类编写切面

切面环绕通知

cotroller配置

附录(一个bug)


spring gateway 统一日志记录 spring操作日志_spring
讯享网

基于需求,思考了下,首先,每个模块需要可配置化,且需要灵活配置到各个类和方法上;其次,需要一个统一的模块去处理日志相关的东西。因此我选择了基于注解的方式,可以灵活配置到方法或者类上。然后基于springAOP实现统一的拦截和日志功能。

java注解

注解同 classs 和 interface 一样,注解也属于一种类型。它是在 Java SE 5.0 版本中开始引入的概念。类似于标签的概念,基础用法如下

Spring AOP

AOP,即 Aspect Oriented Programming:面向切面编程,将程序抽象成各个切面,spring的核心概念之一,可以拦截指定的方法并且对方法增强,而且无需侵入到业务代码中,采取横向抽取机制(动态代理),取代了传统纵向继承机制的重复性代码,其应用主要体现在事务处理、日志管理、权限控制、异常处理等方面。

几个AOP的核心概念:

  • 切面(Aspect):切面是通知和切点的结合。
  • 连接点(join point): 连接点表示应用执行过程中能够插入切面的一个点,这个点可以是方法的调用、异常的抛出。在 Spring AOP 中,连接点总是方法的调用。
  • 通知(Advice): AOP 框架中的增强处理。通知描述了切面何时执行以及如何执行增强处理。
  • 目标对象(Target):目标对象指将要被增强的对象。
  • 切点(PointCut): 可以插入增强处理的连接点。
  • 引入(Introduction):引入允许我们向现有的类添加新的方法或者属性。
  • 织入(Weaving): 将增强处理添加到目标对象中,并创建一个被增强的对象,这个过程就是织入。
  • 顾问(Advisor):顾问是Advice的一种包装体现,Advisor是Pointcut以及Advice的一个结合,用来管理Advice和Pointcut。

相关解释

定义日志类

有些使用了swagger的注解

定义一个切面类编写切面

具体代码如下:

切面环绕通知

需求为当调用方法后,如果方法正常需要插入操作日志,异常的话,需要记录异常信息,所以需要捕获异常信息,并且需要拿到相关的返回值及相关参数,具体实现都在下面方法注释

cotroller配置

controller如下,使用AOP捕获了swagger  @Api注解中的信息作为模块,@ApiOperation中的注解作为操作的数据,将自定义的@SystemLog注解加到了 类上

启动项目,调用方法类,可以看到日志数据成功插入

spring gateway 统一日志记录 spring操作日志_java_02

 最终的返回数据如下:

spring gateway 统一日志记录 spring操作日志_spring boot_03

至此,操作日志的集成算是完成了 

当controller类中的方法为private修饰时,会发生报错的情况

原因及解决:

Spring AOP使用的是CGLIB代理,该代理的原理是:

动态生成一个要代理类的子类,子类重写要代理的类的所有不是final的方法。在子类中采用方法拦截的技术拦截所有父类方法的调用,顺势织入横切逻辑。它比使用java反射的JDK动态代理要快。

换言之,由CGLIB创建的代理类,不会包含父类中的私有方法。另外由于CGLIB代理类的生成过程,决定了其成员(无论是private还是protected)均是null。

或者说调用private/public方法时,对象是代理对象还是实际的spring管理的controller对象。进入目标方法时,private类型时当前this是代理对象,public类型时当前this是际的spring管理的controller对象。

解决:将方法修饰符改为public

小讯
上一篇 2025-04-24 20:20
下一篇 2025-05-16 10:17

相关推荐

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容,请联系我们,一经查实,本站将立刻删除。
如需转载请保留出处:https://51itzy.com/kjqy/205220.html