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),关键在于正确构造请求、设置头信息、处理响应和错误。
最常用的是获取数据。推荐用 http.Get 快速发起请求,但要注意它会自动关闭连接,且无法自定义超时或 Header;生产环境建议用自定义 http.Client。
适合简单调试):resp, err := http.Get("https://httpbin.org/get")
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)
发送结构化数据常用 application/json 或 application/x-www-form-urlencoded。
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)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 分支也别遗漏真实项目常需额外控制,比如 Basic Auth、TLS 配置、连接池或重试机制。
req.SetBasicAuth("user", "pass")
tr := &http.Transport{TLSClientConfig: &tls.Config{InsecureSkipVerify: true}}
time.Sleep,配合指数退避