17370845950

如何使用Golang创建HTTP客户端请求_Golang net HTTP Client请求方法说明
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.Clienthttp.NewRequest 和处理响应。

基础 GET 请求(最常用)

直接用 http.Get 最快,适合简单无头信息、无超时控制的场景:

  • 它内部会创建默认 http.Client,自动处理重定向(最多 10 次)
  • 返回 *http.Responseerror,必须手动调用 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 实例,它本身是并发安全的,适合高并发场景
  • 若需禁用重定向,设 CheckRedirecthttp.ErrUseLastResponse

发送 POST 表单或 JSON 数据

http.NewRequest 构造请求对象,再交由 client.Do 执行:

  • 发表单: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 关闭、状态码判断这三个易错点。