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

若依学习(前后端分离版)——自定义注解@Log(如何自定义注解,实现aop)

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

第一步:自定义注解log

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

第二步切面逻辑处理

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

handleLog()方法

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

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

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

http://www.lryc.cn/news/29163.html

相关文章:

  • 防止暴力破解ssh的四种方法
  • jsp试卷分析管理系统Myeclipse开发mysql数据库web结构java编程计算机网页项目
  • 可选链运算符(?.)与空值合并运算符(??)
  • JavaScript 闭包
  • 每日记录自己的Android项目(二)—Viewbinding,WebView,Navigation
  • 20230305英语学习
  • 【Linux】手把手教你在CentOS上使用docker 安装MySQL8.0
  • 论文解读:High Dynamic Range and Super-Resolution from Raw Image Bursts
  • 国内的PMP考试通过率高达97%?
  • IOC(概念和原理)
  • 操作系统 - 第二章
  • 进程控制~
  • HCIP第一个实验
  • 阿里云轻量服务器--Docker--dubbo-admin安装(连接zookeeper nacos)
  • 树莓派Pico W无线WiFi开发板使用方法及MicroPython编程实践
  • Redis学习【11】之分布式系统
  • 光速c数列的猜想:光猜
  • 2023年全国最新交安安全员精选真题及答案12
  • 2023年全国最新安全员精选真题及答案14
  • 让Vue响应Map或Set的变化操作,在vue中响应map和set数据结构,计算属性的用法,计算属性特点
  • Unable to find a valid cuDNN algorithm to run convolution
  • Linux 进程:进程退出返回值的获取
  • JavaScript核心高级内容复习1
  • 2D图像处理:Qt + Opencv使用光度立体法检测Halcon中提供的缺陷图像
  • 怎样用sql去查一个订单表中一个店铺一段时间的营业收入的环比
  • SpringSecurity: 默认添加的15个Filter是怎么添加进去的?
  • 学习记录---latent code 潜在编码
  • Cesium三维数据格式以及生产流程详解(glb,osgb,obj,bim,ifc)等
  • 2023年备考信息安全工程师每日知识点(1)
  • Unity记录3.1-地图-TileMap简单使用、鼠标拖动放置Tile