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

简单记录下gin中使用中间件记录操作日志

  • 1、直接定义中间件
    package middlewareimport ("bytes""encoding/json""fmt""github.com/gin-gonic/gin""go.uber.org/zap""io""strconv""strings"
    )func LoggerMiddleWare() gin.HandlerFunc {return func(ctx *gin.Context) {//请求方式method := ctx.Request.Method//请求路由reqUrlList := strings.Split(ctx.Request.URL.String(), "?")//状态码statusCode := ctx.Writer.Status()//请求ipclientIP := ctx.ClientIP() // 获取请求体数据var data map[string]interface{}body, err := io.ReadAll(ctx.Request.Body)// 等于拷贝一份往下传递,否则下接口的方法中拿不到请求体数据ctx.Request.Body = io.NopCloser(bytes.NewBuffer(body))if err != nil {fmt.Println(err, "????")}err = json.Unmarshal(body, &data)// 记录到数据库中,排除登录接口if reqUrlList[0] != "/api/v1/admin/login" {message := ""if method == "GET" {if len(reqUrlList) == 2 && reqUrlList[1] != "" {message = reqUrlList[1]}} else {if utils.MapToJson(data) != "null" {message = utils.MapToJson(data)}}// TODO 插入到数据库中}// 打印日志//loggerMap := map[string]interface{} {//	"status_code":statusCode,//	"client_ip": clientIP,//	"req_method":method,//	"req_uri": reqUrl,//}//marshal, _ := json.Marshal(loggerMap)loggerStr := fmt.Sprintf("status_code:%s,client_ip:%s,req_method:%s,req_uri:%s", strconv.Itoa(statusCode), clientIP, method, reqUrlList[0])global.Logger.Info("中间件本次请求", zap.String("http", loggerStr))ctx.Next()}
    }
  • 2、在需要使用的地方直接使用就可以,自动会收集日志到数据库中
http://www.lryc.cn/news/158463.html

相关文章:

  • 基于Matlab利用IRM和RRTstar实现无人机路径规划(附上源码+数据+说明+报告+PPT)
  • uniapp使用@microsoft/signalr(报错“ReferenceError: require is not defined“)
  • CloudCompare 二次开发(9)——半径滤波
  • ElementUI浅尝辄止29:Breadcrumb 面包屑
  • ABB MPRC086444-005数字输入模块
  • stable diffusion实践操作-常见lora模型介绍
  • kubeadm 安装k8s
  • 选择最适合您的Bug管理软件:市场比较与推荐
  • Spring MVC的常用注解及用法
  • HTTP和HTTPS的区别、 HTTPS运行原理
  • 统计封闭岛屿的数目
  • 【数据结构与算法系列4】长度最小的子数组
  • 问道管理:底部渐渐抬高 今年反弹时刻或已来临
  • 正规黄金代理的三大要素
  • Spine2D骨骼动画播放器 - 微信小程序版
  • 蓝天转债,双良转债上市价格预测
  • python-爬虫-xpath方法-批量爬取王者皮肤图片
  • go锁--读写锁
  • Unity中Shader的屏幕坐标
  • springboot MongoDB 主从 多数据源
  • 【100天精通Python】Day57:Python 数据分析_Pandas数据描述性统计,分组聚合,数据透视表和相关性分析
  • Unity 切换场景后场景变暗
  • RabbitMQ学习笔记
  • 【C# Programming】类、构造器、静态成员
  • 软件层面缓存基本概念与分类
  • 单片机有哪些分类?
  • 高阶数据结构-----三种平衡树的实现以及原理(未完成)
  • 北斗高精度组合导航终端
  • 低代码平台是否能替代电子表格?
  • qt多个信号如何关联一并处理