Ai
1 Star 0 Fork 0

charis-xiao/myutils

加入 Gitee
与超过 1200万 开发者一起发现、参与优秀开源项目,私有仓库也完全免费 :)
免费加入
文件
克隆/下载
dfsa.go 1.17 KB
一键复制 编辑 原始数据 按行查看 历史
Chao Xiao 提交于 2022-09-14 13:05 +08:00 . fix
package filter
import (
"bytes"
"github.com/gin-gonic/gin"
log "github.com/sirupsen/logrus"
"time"
)
type responseBodyWriter struct {
gin.ResponseWriter
body *bytes.Buffer
}
func (r responseBodyWriter) Write(b []byte) (int, error) {
r.body.Write(b)
return r.ResponseWriter.Write(b)
}
/*
请求之前
*/
func LogAopReq() func(c *gin.Context) {
return func(c *gin.Context) {
//设置日志格式
log.SetFormatter(&log.JSONFormatter{
TimestampFormat: "2006-01-02 15:04:05",
})
// 开始时间
startTime := time.Now()
w := &responseBodyWriter{body: &bytes.Buffer{}, ResponseWriter: c.Writer}
c.Writer = w
// 处理请求
c.Next()
// 结束时间
endTime := time.Now()
// 执行时间
latencyTime := endTime.Sub(startTime)
// 请求方式
reqMethod := c.Request.Method
// 请求路由
reqUri := c.Request.RequestURI
// 状态码
statusCode := c.Writer.Status()
// 请求IP
clientIP := c.Request.Host
log.WithFields(log.Fields{
"status_code": statusCode,
"latency_time": latencyTime,
"client_ip": clientIP,
"req_method": reqMethod,
"req_uri": reqUri,
"response": w.body.String(),
}).Info()
}
}
Loading...
马建仓 AI 助手
尝试更多
代码解读
代码找茬
代码优化
1
https://gitee.com/NaLanYuChen/myutils.git
git@gitee.com:NaLanYuChen/myutils.git
NaLanYuChen
myutils
myutils
v1.0.1

搜索帮助