Gin POST 请求完整流程笔记

这篇笔记梳理了 POST 请求在 Gin 中的完整流程,从 URL 匹配、数据发送,到结构体绑定和返回响应,帮助你理清前后端交互过程。


1. URL 路径决定调用哪个函数

Gin 根据请求的 URL 路径匹配路由,找到对应的处理函数执行。

go 复制代码
r.POST("/register", controller.Register)  // /register → Register()
r.POST("/login", controller.Login)        // /login → Login()

使用 curl 测试:

bash 复制代码
curl -X POST http://localhost:9000/register  # 路径 /register → 调 Register
curl -X POST http://localhost:9000/login     # 路径 /login → 调 Login

URL 路径就是"门牌号",告诉 Gin 请求该交给哪个处理函数。


2. curl 发送 POST 数据的两种方式

方式 1:直接在命令里写 JSON

bash 复制代码
curl.exe -X POST http://localhost:9000/register \
-H "Content-Type: application/json" \
-d '{"username":"lisi","password":"123456"}'

方式 2:用 JSON 文件

bash 复制代码
# data.json 内容:
# {"username":"lisi","password":"123456"}

curl.exe -X POST http://localhost:9000/register \
-H "Content-Type: application/json" \
--data-binary "@data.json"

@ 表示从文件读取数据发送。


3. curl 命令逐块解析

示例命令:

bash 复制代码
curl.exe -X POST http://localhost:9000/v1/todo \
-H "Content-Type: application/json" \
--data-binary "@data.json"
部分 说明
curl.exe curl 工具
-X POST 发 POST 请求
http://localhost:9000/v1/todo 请求地址(URL)
-H "Content-Type: application/json" 请求头:告诉服务器我发的是 JSON
--data-binary "@data.json" 从文件读取 JSON 数据,放入请求 Body

4. c.ShouldBindJSON(&body) 接收数据

在 Gin 后端:

go 复制代码
func Register(c *gin.Context) {
    var body struct {
        Username string `json:"username"`
        Password string `json:"password"`
    }
    c.ShouldBindJSON(&body)

    // 此时:
    // body.Username = "lisi"
    // body.Password = "123456"
}

赋值过程

  1. Gin 读取请求 Body
  2. 根据结构体标签 json:"..." 匹配字段
  3. 将 JSON 数据填入结构体字段
  4. 结构体现在就可以直接使用

5. POST 请求完整流程

txt 复制代码
终端输入:
  curl -X POST /register -d '{"username":"lisi","password":"123456"}'
       ↑ 路径                    ↑ Body 数据

Gin 收到请求:
  → 匹配 POST /register → 找到 Register 函数
  → c.ShouldBindJSON(&body) → 把 Body 装进结构体
  → body.Username = "lisi", body.Password = "123456"
  → 处理业务逻辑
  → c.JSON 返回结果给前端

这就是 POST 请求从发送到返回的完整流程。


6. 对应前端 fetch

curl 命令 前端 JS fetch
-X POST method: 'POST'
-H "Content-Type: application/json" headers: { 'Content-Type': 'application/json' }
--data-binary "@data.json" body: JSON.stringify({...})
URL fetch('/register', {...})

理解 curl 和 fetch 的对应关系,便于测试接口和前端开发对接。

相关推荐
John_ToDebug1 天前
WeakPtr 与 Raw 指针:UAF 如何识别、如何处理、以及 Chromium 的设计哲学
c++·chrome·ai
海绵宝宝的月光宝盒1 天前
SolidWorks 工程图内容丢失(不显示)解决方法
经验分享·笔记·其他·课程设计·制造·学习方法
悠哉悠哉愿意1 天前
【单片机复习笔记】十五届国赛复盘
笔记·单片机·嵌入式硬件·学习
必胜刻1 天前
一个异步生成游戏功能的落地复盘:Redis Stream + WebSocket + 状态补偿
redis·websocket·golang·gin·状态补偿
智者知已应修善业1 天前
【51单片机按键控制1分钟正计时倒计时暂停复位】2024-1-2
c++·经验分享·笔记·算法·51单片机
searchforAI1 天前
长视频和播客怎么变成结构化读书笔记?一套 AI 时代的知识管理方法
人工智能·笔记·gpt·音视频·语音识别
鸢惜1 天前
菜鸟教程学习笔记——html(二)
笔记·html5
创业之路&下一个五年1 天前
序列化与反序列化原理深度笔记
笔记
超人不会飞_Jay1 天前
26.6.3Vue笔记
前端·vue.js·笔记
中屹指纹浏览器1 天前
2026Intl国际化API时区、地域格式化指纹底层原理与系统本地化模块改造全解
经验分享·笔记