当前位置:网站首页 > 产品管理 > 正文

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



目录

前言

思路

技术储备

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

到此这篇springboot aop日志管理(springboot aop操作日志)的文章就介绍到这了,更多相关内容请继续浏览下面的相关推荐文章,希望大家都能在编程的领域有一番成就!

版权声明


相关文章:

  • 日志管理界面设计(日志管理界面设计理念)2026-02-07 10:36:06
  • 文件管理(文件管理视频彻底删除了怎么找回)2026-02-07 10:36:06
  • 产品经理快速入门(产品经理快速入门技巧)2026-02-07 10:36:06
  • 产品经理入门难吗(产品经理很难吗)2026-02-07 10:36:06
  • dm管理工具查看表信息(dm管理工具创建用户)2026-02-07 10:36:06
  • 日志管理功能描述正确的是(日志管理功能描述正确的是什么)2026-02-07 10:36:06
  • springaop实现日志管理及详解(springboot aop日志记录)2026-02-07 10:36:06
  • 产品经理入门书籍推荐(产品经理经典书籍推荐)2026-02-07 10:36:06
  • 文件管理里面删除的照片怎么找回(在文件管理删掉的照片怎么找回)2026-02-07 10:36:06
  • 文件管理在哪里找vivo手机(文件管理在哪里找vivo手机)2026-02-07 10:36:06
  • 全屏图片