「这是我参与11月更文挑战的第26天,活动详情查看:2021最后一次更文挑战」
前言
在很多后台管理系统中,有明确的权限和角色的管控,当然也少不了操作日志的记录。本文将基于Spring 的AOP特性开发一个日志记录功能。下面记录一下整个开发工程
快速开始
使用Spring的AOP特性,首先了解AOP是什么,AOP在程序开发过程中是指面向切面编程,通过预编译和动态代理实现程序功能。AOP中主要有切点、切面、连接点、目标群、通知、织入方式等。通知类型常用的有前置通知、环绕通知、后置通知等,在日志记录的过程中一般使用环绕通知。具体的AOP的相关概念大家不熟悉的可以去查询一下。
版本信息
本次Spring Boot 基于AOP注解实现日志记录功能,主要版本信息如下:
1 | sql复制代码Spring Boot 2.3.0.RELEASE |
主要引入的依赖是aspectjweaver,如果aspectjweaver 和Spring Boot 版本不一致,可能会报找不到切点等相关的异常,可以替换位相关版本即可解决。
1 | xml复制代码<dependency> |
基础信息
实现日志记录功能,主要是将操作日志记录到数据库中或者搜索引擎中,方便查询。在日志中需要记录操作人、操作时间、请求的参数、请求的ip、请求的连接、操作类型等信息。本次示例的建表SQL如下:
1 | less复制代码CREATE TABLE `log_info` ( |
本次将操作类型分为11类包登录、退出、增删改查、导入导出、清空等相关日志操作类别。
1 | scss复制代码@Getter |
Log注解
当数据初始化完成之后,就是编写一个自定义的Log注解。本次使用的注解主要是针对方法进行注解。具体如下:
- @Target:注解的目标位置,主要可以有接口、类、枚举、字段、方法、构造函数、包等位置。可以根据需要进行配置。日志使用的本次基于方法注解。
- @Retention:是指注解保留的位置,可以在源码中、类中、运行中。本次日志操作记录肯定是在运行中使用,所以选择RUNTIME。
- @Documented:字面意思文档,也就是说明该注解将被包含在javadoc中。
1 | less复制代码@Target(ElementType.METHOD) |
LogAspect
定义一个日志的LogAspect切面。在类中需要使用@Aspect和
@Component指明这是一个切面方法在运行中进行扫描包。需要注意的是这个方法中需要定义切面和通知类型。最后根据注解和请求参数中的信息,查询到操作日志需要的信息。由于本次无需登录直接接口请求,所以操作人和操作id在演示中使用了默认值。本次示例只提取了部分操作日志信息,在项目中需要加入的日志信息多,可以根据需求进行修改。
1 | scss复制代码@Aspect |
测试日志
本示例将基于常用的接口进行测试。在Controller方法中,我们调用自定义注解,根据方法的实际使用含义指定方法的model信息和操作类型信息即可。
1 | less复制代码@RequestMapping("user") |
调用接口:http://127.0.0.1:8888/user/getAllUser 返回的数据信息如下。
查看日志表中,可以看到已经新增一条查询用户列表的日志信息。
下面访问其他接口:http://127.0.0.1:8888/user/getUserById?id=1 返回的数据信息如下。
查看日志表中,可以看到已经新增一条获取指定用户的日志信息。
结语
好了,以上就是Spring Boot 基于AOP注解实现日志记录功能的示例,感谢您的阅读,希望您喜欢,如对您有帮助,欢迎点赞收藏。如有不足之处,欢迎评论指正。下次见。
作者介绍:【小阿杰】一个爱鼓捣的程序猿,JAVA开发者和爱好者。公众号【Java全栈架构师】维护者,欢迎关注阅读交流。
本文转载自: 掘金