-
1、直接定义中间件
gopackage middleware import ( "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() //请求ip clientIP := 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、在需要使用的地方直接使用就可以,自动会收集日志到数据库中
简单记录下gin中使用中间件记录操作日志
水痕012023-09-07 10:57
相关推荐
fuquxiaoguang4 小时前
CVE-2026-41690深度解析:一个HTTP请求如何击穿Node.js中间件防线冷小鱼5 小时前
JVM 深度调优实战:从 JDK 8 到 JDK 21 的演进与中间件落地STAT abil5 小时前
docker离线安装及部署各类中间件(x86系统架构)fuquxiaoguang5 小时前
从监控面板到自主修复:AI智能体正在重新定义中间件运维圣·杰克船长5 小时前
kafka专题_大纲介绍fuquxiaoguang1 天前
0.8W跑10B模型:端侧AI的“寒武纪爆发“与中间件的轻量进化van久1 天前
Day24:JWT 权限验证中间件 + 认证授权全套实战(笔记 + 面试题 + 落地步骤)fangzt20102 天前
从零搭建自动驾驶中间件(二):共享内存零拷贝通信的工程实践fangzt20102 天前
从零搭建自动驾驶中间件(三):事件驱动与协程调度的工程实践fangzt20102 天前
从零搭建自动驾驶中间件(五):状态机、诊断与运维——让系统“可观测、可控制“