为了账号安全,请及时绑定邮箱和手机立即绑定

Go-Gin 多次读取请求正文

Go-Gin 多次读取请求正文

Go
饮歌长啸 2022-06-13 16:34:16
在对其数据执行验证后,我试图用它的数据恢复上下文。我需要数据在下一个函数中根据需要继续移动。我是golang的新手,下面的代码是我能做到的。非常感谢任何帮助和更好的方法。提前致谢。验证中间件func SignupValidator(c *gin.Context) {    // Read the Body content    // var bodyBytes []byte    // if c.Request.Body != nil {    //  bodyBytes, _ = ioutil.ReadAll(c.Request.Body)    // }    var user entity.User    if err := c.ShouldBindJSON(&user); err != nil {         validate := validator.New()         if err := validate.Struct(&user); err != nil {              c.JSON(http.StatusBadRequest, gin.H{                 "error": err.Error(),          })          c.Abort()          return        }        // c.Request.Body = ioutil.NopCloser(bytes.NewBuffer(bodyBytes))    }    // Read the Body content    var bodyBytes []byte    if c.Request.Body != nil {        bodyBytes, _ = ioutil.ReadAll(c.Request.Body)    }    fmt.Println(string(bodyBytes)) // this empty    c.Next()}路线auth.POST("login", gin.Logger(), validations.SignupValidator, func(ctx *gin.Context) {            ctx.JSON(200, videoController.Save(ctx))        })
查看完整描述

2 回答

?
跃然一笑

TA贡献1826条经验 获得超6个赞

你可以试试这个。


ByteBody, _ := ioutil.ReadAll(c.Request.Body)

c.Request.Body = ioutil.NopCloser(bytes.NewBuffer(ByteBody))

然后,您可以随意使用 ByteBody,而不会产生副作用c.Request.Body


查看完整回答
反对 回复 2022-06-13
?
森林海

TA贡献2011条经验 获得超2个赞

这是一个使用 两次读取正文的示例ShouldBindBodyWith,请检查:


package main


import (

    "log"

    "net/http"


    "github.com/gin-gonic/gin"

    "github.com/gin-gonic/gin/binding"

)


type ParamsOne struct {

    Username string `json:"username"`

}


type ParamsTwo struct {

    Username string `json:"username"`

}


func main() {

    r := gin.New()

    r.POST("/", func(c *gin.Context) {

        var f ParamsOne

        // Read ones

        if err := c.ShouldBindBodyWith(&f, binding.JSON); err != nil {

            log.Printf("%+v", err)

        }

        log.Printf("%+v", f)

        var ff ParamsTwo

        

        if err := c.ShouldBindBodyWith(&ff, binding.JSON); err != nil {

            log.Printf("%+v", err)

        }

        log.Printf("%+v", ff)

        c.IndentedJSON(http.StatusOK, f)

    })

    r.Run(":4000")

}

输出:


$example: ./example

[GIN-debug] [WARNING] Running in "debug" mode. Switch to "release" mode in production.

 - using env:   export GIN_MODE=release

 - using code:  gin.SetMode(gin.ReleaseMode)


[GIN-debug] POST   /                         --> main.main.func1 (1 handlers)

[GIN-debug] Listening and serving HTTP on :4000

2020/07/05 10:47:03 {Username:somename}

2020/07/05 10:47:03 {Username:somename}


查看完整回答
反对 回复 2022-06-13
  • 2 回答
  • 0 关注
  • 301 浏览
慕课专栏
更多

添加回答

举报

0/150
提交
取消
微信客服

购课补贴
联系客服咨询优惠详情

帮助反馈 APP下载

慕课网APP
您的移动学习伙伴

公众号

扫描二维码
关注慕课网微信公众号