Go 的 net/http 包提供简洁高效的 HTTP 客户端能力,基础 GET 用 http.Get 最快但需手动关闭 resp.Body;生产环境推荐自定义 http.Client 以控制超时、重试等;POST 需用 http.NewRequest 构造并设置 Content-Type;响应需检查 StatusCode 而非仅依赖 err,且必须关闭 resp.Body 防泄漏。

Go 的 net/http 包提供了简洁、高效、并发安全的 HTTP 客户端能力,不需要额外依赖就能发起 GET、POST 等常见请求,关键在于正确使用 http.Client、http.NewRequest 和处理响应。
基础 GET 请求(最常用)
直接用 http.Get 最快,适合简单无头信息、无超时控制的场景:
- 它内部会创建默认
http.Client,自动处理重定向(最多 10 次) - 返回
*http.Response和error,必须手动调用resp.Body.Close()防止连接泄漏 - 示例:
resp, err := http.Get("https://api.example.com/data")
if err != nil { log.Fatal(err) }
defer resp.Body.Close()
body, _ := io.ReadAll(resp.Body)
自定义 Client 发起带配置的请求
生产环境推荐显式创建 http.Client,便于控制超时、重试、代理、TLS 设置等:
- 设置
Timeout防止请求无限挂起(如:&http.Client{Timeout: 10 * time.Second}) - 可复用 client 实例,它本身是并发安全的,适合高并发场景
- 若需禁用重定向,设
CheckRedirect为http.ErrUseLastResponse
发送 POST 表单或 JSON 数据
用 http.NewRequest 构造请求对象,再交由 client.Do 执行:
立即学习“go语言免费学习笔记(深入)”;
- 发表单:
req, _ := http.NewRequest("POST", url, strings.NewReader("name=alice&age=30")),记得设req.Header.Set("Content-Type", "application/x-www-form-urlencoded") - 发 JSON:
data, _ := json.Marshal(map[string]string{"msg": "hello"}),然后req, _ := http.NewRequest("POST", url, bytes.NewReader(data)),并设req.Header.Set("Content-Type", "application/json") - 所有自定义 header 必须在
client.Do(req)前设置
处理响应与错误
HTTP 状态码不等于错误 —— 即使返回 404 或 500,err 仍可能是 nil,需主动检查 resp.StatusCode:
- 读取响应体前先检查
resp.StatusCode >= 200 && resp.StatusCode - 用
io.ReadAll(resp.Body)获取完整响应内容,避免只读部分导致 body 未关闭 - 网络错误(如连接失败、DNS 解析失败)才会触发
err != nil;服务端返回错误状态码属于正常 HTTP 通信流程
基本上就这些。Golang 的 HTTP 客户端设计直白,重点在于理解 client 复用、body 关闭、状态码判断这三个易错点。










