应先检查 resp.StatusCode 是否在 200–299 范围,再读取响应体;非预期状态码需显式读取并关闭 resp.Body;用 io.ReadAll 时须限流防 OOM。

Go 的 net/http 包提供了简洁而强大的 HTTP 客户端能力,解析响应的关键在于正确读取、解码和处理 *http.Response 对象。核心不是“怎么拿到响应”,而是“如何安全、高效、健壮地消费它”。
很多新手直接调用 resp.Body.Read() 或 io.ReadAll(),却忽略了服务端可能返回 4xx/5xx 状态码。此时响应体仍可能存在(比如错误详情),但你不该默认当作成功数据处理。
resp.StatusCode 是否在 200–299 范围内,或按业务需要定义可接受范围(如 2xx 和 304)resp.Body(避免连接复用异常),再返回错误defer resp.Body.Close() —— 即使出错也要关io.ReadAll(resp.Body) 简单直接,但若服务端返回超大响应(如未分页的百万条数据),会一次性加载进内存导致 OOM。
io.LimitReader(resp.Body, maxBytes) 限制读取上限body, err := io.ReadAll(io.LimitReader(resp.Body, 10(限 10MB)
相比先读全部字节再 json.Unmarshal,json.NewDecoder(resp.Body) 更省内存、支持流式解析,且能自动处理编码(如 UTF-8 BOM)。
立即学习“go语言免费学习笔记(深入)”;
resp.Body: err := json.NewDecoder(resp.Body).Decode(&v)
Decode 内部会读完所需部分(除非出错)json.NewDecoder 循环调用 Decode
HTTP 响应头中的 Content-Type 可能带 charset=...(如 application/json; charset=utf-8)。Go 标准库的 json 包只支持 UTF-8/UTF-16/UTF-32,且默认按 UTF-8 解析。
json.Decoder 会自动跳过utf-8 实际发 GBK,需先用 golang.org/x/text/encoding 转码再解 JSONresp.Header.Get("Content-Type") 辅助调试基本上就这些 —— 不复杂,但每一步都容易忽略细节。重点不是语法多炫,而是养成检查状态、控制资源、信任但验证内容的习惯。
以上就是如何使用Golang处理HTTP响应_Golang net HTTP Response解析技巧的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号