Go语言处理HTTP响应需通过net/http库获取*http.Response对象,首先检查StatusCode是否为2xx以判断业务成功,再用defer resp.Body.Close()确保资源释放;接着用io.ReadAll读取Body内容,对JSON数据可定义结构体并使用json.Unmarshal解析,注意字段映射;非200状态需结合响应体返回自定义错误;网络层错误由err返回,应用层需手动判断状态码;建议使用带Timeout的自定义Client避免阻塞。

Go语言处理HTTP响应内容非常直接,主要通过标准库net/http完成。发送HTTP请求后,程序会收到一个*http.Response对象,开发者需要从中读取状态、头信息和响应体,并正确关闭资源。
获取并读取响应体内容
使用http.Get或http.Client.Do发起请求后,返回的Response中包含一个Body字段,类型为io.ReadCloser。必须调用defer resp.Body.Close()避免资源泄漏。
常用ioutil.ReadAll一次性读取完整响应内容:
- 导入
"io/ioutil"(Go 1.16前)或使用io.ReadAll(推荐) - 将
resp.Body传入读取函数,得到字节切片[]byte - 转换为字符串即可查看原始内容
解析JSON格式响应
多数API返回JSON数据,Go可通过json.Unmarshal将其解析到结构体中。
立即学习“go语言免费学习笔记(深入)”;
定义结构体字段时,建议使用标签json:"field_name"映射JSON键名:
- 创建与响应结构匹配的struct
- 使用
json.Unmarshal(body, &targetStruct)填充数据 - 检查返回的error判断是否解析成功
若结构未知,也可解析为map[string]interface{}或interface{},但访问时需类型断言。
处理非200状态码与错误
http.Get不会因HTTP状态码返回错误,即使服务器返回404或500,err仍为nil。需手动判断resp.StatusCode。
- 检查
resp.StatusCode是否在200~299范围内 - 若不符合,可结合响应体中的错误信息返回自定义错误
- 网络连接失败等场景才会触发非nil的
err
设置超时与自定义客户端
默认的http.Get无超时,可能造成程序阻塞。建议使用自定义http.Client并设置Timeout。
- 创建
client := &http.Client{Timeout: 10 * time.Second} - 用
client.Do(req)发送请求 - 可进一步配置Transport实现重试、代理等功能
基本上就这些。处理HTTP响应的核心是读取Body、解析内容、检查状态码和及时释放资源。配合结构体标签和错误处理,能高效对接各类Web服务。不复杂但容易忽略细节,比如忘记Close或误判错误。










