Go 中 HTTP 客户端推荐用自定义 http.Client(设超时、Header 等),而非快捷函数;需手动检查 resp.StatusCode 和 err,始终 defer resp.Body.Close();进阶支持认证、自定义 Transport 和重试。

在 Go 语言中,使用标准库 net/http 实现 HTTP 客户端请求非常简洁高效。核心是 http.Client 和 http.NewRequest(或更便捷的快捷函数如 http.Get、http.Post),关键在于正确构造请求、设置头信息、处理响应和错误。
发送 GET 请求并读取响应
最常用的是获取数据。推荐用 http.Get 快速发起请求,但要注意它会自动关闭连接,且无法自定义超时或 Header;生产环境建议用自定义 http.Client。
- 使用快捷方式(适合简单调试):
resp, err := http.Get("https://httpbin.org/get") - 使用自定义 Client(推荐):
client := &http.Client{Timeout: 10 * time.Second}
req, _ := http.NewRequest("GET", "https://httpbin.org/get", nil)
req.Header.Set("User-Agent", "MyApp/1.0")
resp, err := client.Do(req) - 务必检查
err和resp.StatusCode,再读取resp.Body:defer resp.Body.Close()
body, _ := io.ReadAll(resp.Body)
发送 POST 请求(表单或 JSON)
发送结构化数据常用 application/json 或 application/x-www-form-urlencoded。
- 发送 JSON:
data := map[string]string{"name": "Alice"}
jsonBytes, _ := json.Marshal(data)
resp, err := http.Post("https://httpbin.org/post", "application/json", bytes.NewBuffer(jsonBytes)) - 发送表单:
values := url.Values{"name": {"Alice"}, "age": {"30"}}
resp, err := http.PostForm("https://httpbin.org/post", values) - 若需更多控制(如加 Header、设超时),仍建议用
NewRequest+Client.Do构造 POST 请求
处理响应状态与错误
Go 的 HTTP 客户端不会因 4xx/5xx 状态码自动报错,err 仅表示网络或协议错误。业务逻辑需手动判断状态码。
立即学习“go语言免费学习笔记(深入)”;
-
if err != nil→ 检查网络、DNS、连接失败等底层问题 -
if resp.StatusCode = 300→ 处理业务异常(如 404、401、500) - 始终调用
resp.Body.Close()防止资源泄漏,尤其在 error 分支也别遗漏
带认证、重试或自定义 Transport 的进阶用法
真实项目常需额外控制,比如 Basic Auth、TLS 配置、连接池或重试机制。
- Basic 认证:
req.SetBasicAuth("user", "pass") - 自定义 Transport(如禁用 HTTPS 证书校验,仅测试用):
tr := &http.Transport{TLSClientConfig: &tls.Config{InsecureSkipVerify: true}} - 重试逻辑需手动实现(标准库不内置),通常用 for 循环 +
time.Sleep,配合指数退避










