【GoWeb】GIN获取POST请求的JSON参数

本文展示了如何使用前端的Ajax与后端的Gin框架进行数据交互。前端通过Axios发送POST请求,传递JSON数据,如'title'。后端Gin中,利用context.BindJSON()方法解析接收到的JSON,将数据绑定到预先定义的Todo模型上,并通过数据库操作创建新记录。在处理错误和返回响应时,后端会返回相应的HTTP状态码和数据。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

前端

一个简单的ajax请求

        this.axios
          .post("/v1/todo", {
            title: this.newTitle
          }) // localhost:8080/vi/todo
          .then(() => {
			// dosometing
          });

后端

使用context.BindJSON()绑定JSON数据,前提是需要把数据模型定义好。比如传进来的JSON包括一个“title”的key,那么定义的数据模型也要有相应接收的字段。

	// todo Model
type Todo struct {
	Title string `json:"title"`
	Status bool `json:"status"`
	gorm.Model
}

	v1 := r.Group("/v1")
	{
		v1.POST("/todo", func(context *gin.Context) {
			var tmp Todo
			context.BindJSON(&tmp)   // 绑定JSON数据

			if err = db.Create(&tmp).Error ; err != nil{
				context.JSON(http.StatusOK, gin.H{
					"ERROR": err.Error(),
				})
			}else{
				context.JSON(http.StatusOK, tmp)
			}
		})
	}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值