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

  • 1、直接定义中间件

    go 复制代码
    package 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、在需要使用的地方直接使用就可以,自动会收集日志到数据库中

相关推荐
愚公搬代码3 小时前
【愚公系列】《移动端AI应用开发》014-DeepSeek API开发与集成(处理多轮对话与动态请求)
人工智能·中间件·架构
Trouvaille ~3 小时前
【Redis篇】Redis 主从复制:数据同步的原理与实现
数据库·redis·缓存·中间件·高可用·主从复制·后端开发
唔664 小时前
(二)补充完整的数据库、中间件、MQTT、JAR后台和Web前端的部署脚本,全部一键自动化。
数据库·中间件·jar
愚公搬代码7 小时前
【愚公系列】《移动端AI应用开发》013-DeepSeek API开发与集成(深度集成与中间件架构)
人工智能·中间件·架构
必胜刻1 天前
一个异步生成游戏功能的落地复盘:Redis Stream + WebSocket + 状态补偿
redis·websocket·golang·gin·状态补偿
li星野1 天前
FastAPI 中间件完全指南:从原理到实战,掌控请求响应的全局钩子
中间件·fastapi
Hello:CodeWorld1 天前
LangChain V1.x 新版框架全解析|从架构、核心组件到中间件、结构化输出实战
中间件·架构·langchain
我是一颗柠檬1 天前
【Java项目技术亮点】Outbox事件驱动模式:解决分布式事务的终极方案
java·开发语言·分布式·后端·中间件·kafka
SilentSamsara2 天前
高并发 API 压测与调优:locust + 火焰图 + 瓶颈定位
开发语言·python·青少年编程·docker·中间件
TE-茶叶蛋2 天前
B-tree vs GIN Trigram vs HNSW
gin