Gin 中 `c.BindJSON` 与 `c.JSON` 详细讲解

在 Gin 中,c.BindJSONc.JSON 是前后端交互的两个核心操作,它们构成了数据从前端到后端再返回前端的完整链路。


1. c.BindJSON:接收前端数据

假设前端发送 POST 请求:

json 复制代码
{"title":"学Gin","status":false}

后端代码:

go 复制代码
var body struct {
    Title  string `json:"title"`
    Status bool   `json:"status"`
}
c.BindJSON(&body)

赋值过程详解:

  1. 读取 Body

    • Gin 从 HTTP 请求中获取请求 Body。
    • Body 是原始 JSON 数据:{"title":"学Gin","status":false}
  2. 解析 JSON

    • Gin 调用 Go 标准库 encoding/json 对 JSON 进行解析。
  3. 结构体字段匹配

    • 标签 json:"title" 对应 Go 的 Title
    • 标签 json:"status" 对应 Go 的 Status
  4. 填充值

    • "title":"学Gin"body.Title = "学Gin"
    • "status":falsebody.Status = false

此时,结构体 body 中的数据已经完全对应前端发送的数据。

go 复制代码
fmt.Println(body.Title)  // 输出: 学Gin
fmt.Println(body.Status) // 输出: false

总结:c.BindJSON 的作用是"拆包 + 填字段",把前端 JSON 数据装入 Go 结构体中,方便后续业务逻辑使用。


2. c.JSON:返回数据给前端

处理完数据后,后端需要把结果返回给前端,常用方法是 c.JSON

go 复制代码
c.JSON(200, gin.H{
    "message": "创建成功",
    "todo":    body,
})

执行过程:

  1. 接收 Go 对象

    • gin.H 是 mapstringinterface{} 的简写,用于快速构造 JSON 数据
    • 结构体 body 也可以直接返回
  2. 序列化 JSON

    • Gin 内部使用 encoding/json.Marshal 将 Go 对象转换成 JSON 字符串
    • 结构体标签 json:"..." 决定了 JSON 字段名
      • Title"title"
      • Status"status"
  3. 返回 HTTP 响应

    • 状态码 200
    • 响应 Body 为 JSON 字符串:
json 复制代码
{
  "message": "创建成功",
  "todo": {
    "title": "学Gin",
    "status": false
  }
}

总结:c.JSON 的作用是"打包 + 发快递",把 Go 对象转换成 JSON 返回给前端。


3. 前后端完整交互流程

txt 复制代码
前端 JSON.stringify → 发 POST 请求
        ↓
Gin c.BindJSON → 装进结构体
        ↓
业务逻辑处理
        ↓
Gin c.JSON → 转 JSON → 返回前端
        ↓
前端 JSON.parse → 更新页面

示例代码:

go 复制代码
type Todo struct {
    Title  string `json:"title"`
    Status bool   `json:"status"`
}

r.POST("/todos", func(c *gin.Context) {
    var body Todo
    if err := c.BindJSON(&body); err != nil {
        c.JSON(400, gin.H{"error": err.Error()})
        return
    }

    // 假设保存数据库成功
    c.JSON(200, gin.H{
        "message": "创建成功",
        "todo":    body,
    })
})

4. 总结

方法 作用 数据方向
c.BindJSON(&struct) 接收前端 JSON,填入 Go 结构体 前端 → 后端
c.JSON(status, obj) 将 Go 对象转换成 JSON,返回前端 后端 → 前端

结合使用 c.BindJSON + c.JSON,就完成了前后端的数据闭环,实现了完整的请求处理和响应返回。

相关推荐
三品吉他手会点灯18 小时前
C语言学习笔记 - 43.运算符与表达式 - 运算符1 - 运算符的分类和简单介绍
c语言·笔记·学习·算法
wuminyu21 小时前
Java锁机制之轻量级锁判断与尝试逻辑源码剖析
java·linux·c语言·jvm·c++
老H科研技术1 天前
第 01 篇:MCP 概念与架构 —— AI 世界的“USB-C“
c语言·人工智能·chatgpt·架构·aigc·agi
ward RINL1 天前
WorkBuddy 自定义模型配置踩坑记录:models.json、/v1、API Key 一次讲清楚
json
m0_738120721 天前
渗透测试基础——一文详解JSONP跨域劫持漏洞原理与利用
服务器·安全·web安全·json
社交怪人1 天前
【判断奇偶】信息学奥赛一本通C语言解法(题号1041)
c语言
Jun6261 天前
QT(1)-C/C++库生成和调用
c语言·开发语言·c++·qt
必胜刻1 天前
一个异步生成游戏功能的落地复盘:Redis Stream + WebSocket + 状态补偿
redis·websocket·golang·gin·状态补偿
努力努力再努力wz1 天前
【Qt入门系列】一文掌握 Qt 常用显示类控件:QLCDNumber、QProgressBar 与 QCalendarWidget
c语言·开发语言·数据结构·数据库·c++·git·qt
C++ 老炮儿的技术栈1 天前
如何利用 OpenCV 将图像显示在对话框窗口上
c语言·c++·人工智能·qt·opencv·计算机视觉·github