如何优雅的在Gin框架中打印request body?

一、在Gin框架中打印request body

前面有篇文章介绍了,通过在中间件中读取body的内容,然后在打印,最后在通过ioutil.NopCloser把读取的内容从新赋值给body,解决只能读一次问题。

下面介绍另一种方式,避免多次Unmarshal和内存拷贝。

二、使用gin.Context的set和get方法

1.方法处理结束后调用c.Set要打印的值

func LoginHandler(c *gin.Context){
	// 假设loginDTO是接收POST方法传递的参数
	var loginDTO LoginDTO
	var err error
	// Unmarshal参数到loginDTO
	if err = c.ShouldBindJSON(&loginDTO);err!=nil{
		// TODO 这里返回自定义的错误提示,代码省略若干行。。。
		return
	}
	// 解析成功,则把用户参数set到params中
	defer c.Set("params",loginDTO)

	return
}

2.在非业务中间件中调用c.Get获取要打印的值

func LoggerMiddleWare() gin.HandlerFunc {
	return func(c *gin.Context) {
		// 此处省略若干行。。。
		// 注意:在Next之前不读取body的内容
		c.Next()
		params:=c.Get("params")
		// 自定义打印,此处只是简单举例
		log.Printf("Request params:%v",params)
	}
}

总结

本文通过gin.Context对象的Set和Get方法以及中间件的使用,优雅的完成了请求参数的打印功能,避免在每个业务方法中打印请求参数的问题,同时避免使用ioutil.NopCloser需要赋值一次内存的方式。

  • 2
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 2
    评论
gin 框架,批量增删改操作可以通过 HTTP POST 请求来实现,请求的 body 包含操作类型和数据,服务器端根据操作类型执行对应的增删改操作。以下是一个示例代码,实现批量增删改用户的功能: ```go type User struct { ID int `json:"id"` Name string `json:"name"` Age int `json:"age"` } var users = []User{ {ID: 1, Name: "Alice", Age: 20}, {ID: 2, Name: "Bob", Age: 25}, {ID: 3, Name: "Charlie", Age: 30}, } type BatchRequest struct { Op string `json:"op"` // 操作类型,可以是 add, update 或 delete Users []User `json:"users"` // 待操作的用户列表 } func main() { r := gin.Default() r.POST("/batch", func(c *gin.Context) { var batchReq BatchRequest if err := c.BindJSON(&batchReq); err != nil { c.JSON(http.StatusBadRequest, gin.H{"error": err.Error()}) return } switch batchReq.Op { case "add": for _, user := range batchReq.Users { users = append(users, user) } case "update": for _, user := range batchReq.Users { for i := range users { if users[i].ID == user.ID { users[i] = user break } } } case "delete": ids := make(map[int]bool) for _, user := range batchReq.Users { ids[user.ID] = true } newUsers := make([]User, 0, len(users)) for _, user := range users { if !ids[user.ID] { newUsers = append(newUsers, user) } } users = newUsers default: c.JSON(http.StatusBadRequest, gin.H{"error": "invalid operation type"}) return } c.JSON(http.StatusOK, gin.H{"message": "success"}) }) r.Run(":8080") } ``` 在上述代码,我们定义了一个 `User` 结构体,包含用户的 ID、姓名和年龄。我们使用一个全局变量 `users` 来保存所有用户的信息。在路由处理函数,我们首先解析 HTTP 请求的 JSON 数据,然后根据 `BatchRequest.Op` 的值执行对应的增删改操作。具体来说: - 如果 `Op` 是 `"add"`,就将请求的所有用户添加到 `users` ; - 如果 `Op` 是 `"update"`,就将请求的所有用户的信息更新到 `users` ; - 如果 `Op` 是 `"delete"`,就将请求的所有用户从 `users` 删除。 最后,我们返回一个 JSON 响应,表示操作成功。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

空间法则

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值