0

0

如何正确解析 Go HTTP 请求中的查询参数与请求体数据

心靈之曲

心靈之曲

发布时间:2026-01-03 19:37:02

|

507人浏览过

|

来源于php中文网

原创

如何正确解析 Go HTTP 请求中的查询参数与请求体数据

本文详解 go 中 `net/http` 请求体为空的原因,指出 get 请求的参数位于 url 查询字符串而非请求体,并提供使用 `req.parseform()` 解析表单/查询参数、以及正确处理 json 请求体的完整方案。

在 Go 的 net/http 包中,req.Body 仅承载 HTTP 请求消息体(body)中的原始数据,例如 POST/PUT 请求中通过 Content-Type: application/json 发送的 JSON 内容。而你当前的 AJAX 请求使用的是 method: "get",所有参数(steps、direction、cells)均被拼接在 URL 查询字符串中(如 /step?steps=1&direction=1&cells=...),根本不会写入请求体——因此 req.Body 为空(甚至可能为 nil),json.Decoder 自然无法解码,最终得到

✅ 正确做法取决于你的实际需求:

✅ 场景一:你本意就是读取 URL 查询参数(GET 请求)

无需操作 req.Body,应调用 req.ParseForm(),然后从 req.Form 或 req.URL.Query() 中提取值:

func stepHandler(res http.ResponseWriter, req *http.Request) {
    // 必须先调用 ParseForm(对 GET/POST 均有效)
    if err := req.ParseForm(); err != nil {
        http.Error(res, "Failed to parse form", http.StatusBadRequest)
        return
    }

    // 从查询参数中获取值(自动解码 URL 编码)
    steps := req.FormValue("steps")           // "1"
    direction := req.FormValue("direction")   // "1"
    cellsJSON := req.FormValue("cells")       // "[{\"row\":11,\"column\":15},...]"

    // 若 cells 是 JSON 字符串,需二次解析
    var cells []map[string]interface{}
    if err := json.Unmarshal([]byte(cellsJSON), &cells); err != nil {
        http.Error(res, "Invalid cells JSON", http.StatusBadRequest)
        return
    }

    log.Printf("Steps: %s, Direction: %s, Cells: %+v", steps, direction, cells)
}
? 补充说明:req.FormValue(key) 是安全便捷的方式,它会自动调用 ParseForm()(若未调用过),并返回首个匹配键的值(已 URL 解码)。对于 GET 请求,req.URL.Query() 效果相同,但 req.Form 更通用(兼容 POST 表单)。

✅ 场景二:你希望真正发送 JSON 到请求体(推荐用于结构化数据)

需将客户端改为 POST,设置 Content-Type: application/json,并在服务端读取 req.Body:

你好星识
你好星识

你的全能AI工作空间

下载

前端(AJAX):

$.ajax({
  url: "/step",
  method: "POST",
  contentType: "application/json",
  data: JSON.stringify({
    steps: parseInt($("#step-size").val()),
    direction: $("#step-forward").prop("checked") ? 1 : -1,
    cells: painted // 直接传数组,无需额外 stringify
  }),
  success: function (data) {
    painted = data;
    redraw();
  }
});

后端(Go):

func stepHandler(res http.ResponseWriter, req *http.Request) {
    // 确保是 POST 且 Content-Type 正确
    if req.Method != "POST" || req.Header.Get("Content-Type") != "application/json" {
        http.Error(res, "Method not allowed", http.StatusMethodNotAllowed)
        return
    }

    var payload struct {
        Steps     int           `json:"steps"`
        Direction int           `json:"direction"`
        Cells     []struct {
            Row    int `json:"row"`
            Column int `json:"column"`
        } `json:"cells"`
    }

    if err := json.NewDecoder(req.Body).Decode(&payload); err != nil {
        http.Error(res, "Invalid JSON", http.StatusBadRequest)
        return
    }
    defer req.Body.Close() // ⚠️ 切记关闭 Body!

    log.Printf("Steps: %d, Direction: %d, Cells: %+v", 
        payload.Steps, payload.Direction, payload.Cells)
}

⚠️ 关键注意事项

  • req.Body 不可重复读取:一旦被 json.Decoder 或 ioutil.ReadAll 消费,再次读取将返回空。务必在需要时只读一次,并及时 Close()。
  • req.ParseForm() 对 GET 请求解析 URL.Query(),对 POST 解析 application/x-www-form-urlencoded 或 multipart/form-data;它不解析 JSON 请求体
  • 混淆 query string(URL 参数)与 request body(消息体)是 Go 新手常见误区。牢记:GET 无 body,参数全在 URL;POST/PUT 的 body 才需 json.Decoder。

选择合适的方式,你的请求数据就能被准确、可靠地解析了。

相关专题

更多
json数据格式
json数据格式

JSON是一种轻量级的数据交换格式。本专题为大家带来json数据格式相关文章,帮助大家解决问题。

403

2023.08.07

json是什么
json是什么

JSON是一种轻量级的数据交换格式,具有简洁、易读、跨平台和语言的特点,JSON数据是通过键值对的方式进行组织,其中键是字符串,值可以是字符串、数值、布尔值、数组、对象或者null,在Web开发、数据交换和配置文件等方面得到广泛应用。本专题为大家提供json相关的文章、下载、课程内容,供大家免费下载体验。

530

2023.08.23

jquery怎么操作json
jquery怎么操作json

操作的方法有:1、“$.parseJSON(jsonString)”2、“$.getJSON(url, data, success)”;3、“$.each(obj, callback)”;4、“$.ajax()”。更多jquery怎么操作json的详细内容,可以访问本专题下面的文章。

308

2023.10.13

go语言处理json数据方法
go语言处理json数据方法

本专题整合了go语言中处理json数据方法,阅读专题下面的文章了解更多详细内容。

74

2025.09.10

ajax教程
ajax教程

php中文网为大家带来ajax教程合集,Ajax是一种用于创建快速动态网页的技术。通过在后台与服务器进行少量数据交换,Ajax可以使网页实现异步更新。这意味着可以在不重新加载整个网页的情况下,对网页的某部分进行更新。php中文网还为大家带来ajax的相关下载资源、相关课程以及相关文章等内容,供大家免费下载使用。

146

2023.06.14

ajax中文乱码解决方法
ajax中文乱码解决方法

ajax中文乱码解决方法有设置请求头部的字符编码、在服务器端设置响应头部的字符编码和使用encodeURIComponent对中文进行编码。本专题为大家提供ajax中文乱码相关的文章、下载、课程内容,供大家免费下载体验。

159

2023.08.31

ajax传递中文乱码怎么办
ajax传递中文乱码怎么办

ajax传递中文乱码的解决办法:1、设置统一的编码方式;2、服务器端编码;3、客户端解码;4、设置HTTP响应头;5、使用JSON格式。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

109

2023.11.15

ajax网站有哪些
ajax网站有哪些

使用ajax的网站有谷歌、维基百科、脸书、纽约时报、亚马逊、stackoverflow、twitter、hacker news、shopify和basecamp等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

226

2024.09.24

漫画合集pdf网盘入口_漫画解说合集一口气看完
漫画合集pdf网盘入口_漫画解说合集一口气看完

精选高人气漫画合集PDF,一站式网盘入口直达!深度漫画解说整合,一口气看完经典与新作,剧情梳理清晰,省时省力,追漫党必看合集。

7

2026.01.04

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
WEB前端教程【HTML5+CSS3+JS】
WEB前端教程【HTML5+CSS3+JS】

共101课时 | 8.1万人学习

JS进阶与BootStrap学习
JS进阶与BootStrap学习

共39课时 | 3.1万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号