若依学习(前后端分离版)——自定义注解@Log(如何自定义注解,实现aop)
创始人
2024-05-28 20:10:42
0

如何自定义注解
aop的基本知识与应用
若依对用户的一些更新删除等敏感操作操作进行了日志记录
在这里插入图片描述
在这里插入图片描述
注解定义和切面处理的项目位置
在这里插入图片描述

第一步:自定义注解log

定义了注解的相关信息。这里定义的属性可以在使用时加以定义
注解@Target和@Retention的作用
在这里插入图片描述
在这里插入图片描述

第二步切面逻辑处理

首先明确了在请求处理完和出现异常都要进行逻辑处理,切入点为Log注解,拦截了返回值,两者都调用了handleLog()方法;
在这里插入图片描述

handleLog()方法

前面只是一些信息的组装,这里利用反射获取了方法名和类名
在这里插入图片描述
这里在记录请求参数时使用fastjson的json参数过滤
JSONObject.toJSONString()包含或排除指定的属性
在这里插入图片描述
如果是put或post请求时,还做了参数拼装,不过在拼装时排除了这几种类型的参数
在这里插入图片描述
在获取请求参数时如果是post或put请求,直接使用了AOP相关的joinPoint.getArgs()方法,其他方式则是通过封装了一下request的方法。
在这里插入图片描述

我们点解详情就可以查看相关信息
在这里插入图片描述

在处理完所有事情后把信息存入数据库
在这里插入图片描述

相关内容

热门资讯

监控摄像头接入GB28181平... 流程简介将监控摄像头的视频在网站和APP中直播,要解决的几个问题是:1&...
Windows10添加群晖磁盘... 在使用群晖NAS时,我们需要通过本地映射的方式把NAS映射成本地的一块磁盘使用。 通过...
protocol buffer... 目录 目录 什么是protocol buffer 1.protobuf 1.1安装  1.2使用...
在Word、WPS中插入AxM... 引言 我最近需要写一些文章,在排版时发现AxMath插入的公式竟然会导致行间距异常&#...
【PdgCntEditor】解... 一、问题背景 大部分的图书对应的PDF,目录中的页码并非PDF中直接索引的页码...
修复 爱普生 EPSON L4... L4151 L4153 L4156 L4158 L4163 L4165 L4166 L4168 L4...
Fluent中创建监测点 1 概述某些仿真问题,需要创建监测点,用于获取空间定点的数据࿰...
educoder数据结构与算法...                                                   ...
MySQL下载和安装(Wind... 前言:刚换了一台电脑,里面所有东西都需要重新配置,习惯了所...
MFC文件操作  MFC提供了一个文件操作的基类CFile,这个类提供了一个没有缓存的二进制格式的磁盘...