Go中发送GET请求最推荐使用net/http包:基础请求用http.Get,带参请求须用url.Values编码,务必关闭resp.Body并设置超时。

在 Go 语言中发送 GET 请求最常用、最推荐的方式是使用标准库 net/http 包,无需引入第三方依赖,简洁安全。
基础 GET 请求(无参数)
直接调用 http.Get 是最简方式,适合访问不带查询参数的 URL:
- 它会自动发起请求、处理重定向(默认最多 10 次),并返回 *http.Response 和 error
- 响应体(Body)必须手动关闭,否则会造成连接泄漏
- 建议用 defer resp.Body.Close() 确保释放资源
示例:
resp, err := http.Get("https://httpbin.org/get")if err != nil {
log.Fatal(err)
}
defer resp.Body.Close()
body, _ := io.ReadAll(resp.Body)
fmt.Println(string(body))
带查询参数的 GET 请求
不要手动拼接 URL 字符串,应使用 url.Values 编码参数,避免特殊字符(如空格、中文、&)引发错误:
立即学习“go语言免费学习笔记(深入)”;
- 用 url.Parse 解析基础 URL
- 用 url.Values.Set 添加键值对
- 将参数通过 u.RawQuery 注入 URL
示例:
u, _ := url.Parse("https://httpbin.org/get")q := u.Query()
q.Set("name", "张三")
q.Set("age", "25")
u.RawQuery = q.Encode()
resp, err := http.Get(u.String())
if err != nil {
log.Fatal(err)
}
defer resp.Body.Close()
自定义客户端与超时控制
默认的 http.Get 使用全局默认客户端,无法设置超时;生产环境务必自定义 http.Client:
- 通过 http.Client{Timeout: 10 * time.Second} 防止请求无限挂起
- 可进一步配置 Transport(如复用连接、禁用 KeepAlive)
- 超时包括连接、响应头读取、整个请求周期
示例:
client := &http.Client{Timeout: 5 * time.Second,
}
resp, err := client.Get("https://httpbin.org/get")
// 后续处理同上
检查状态码与错误处理
HTTP 状态码不是 2xx 不代表 err != nil(比如 404、500 仍可能返回非 nil resp),需主动判断:
- 先检查 err 是否为网络或协议错误
- 再检查 resp.StatusCode 是否在预期范围内(如 200–299)
- 非成功状态建议统一处理或返回错误
示例片段:
if err != nil {return fmt.Errorf("request failed: %w", err)
}
defer resp.Body.Close()
if resp.StatusCode = 300 {
return fmt.Errorf("HTTP %d: %s", resp.StatusCode, resp.Status)
}
基本上就这些。Go 的 HTTP 客户端设计清晰,关键点就三个:用好 url.Values 编码参数、别忘 Close() Body、一定要设 Timeout。不复杂但容易忽略。










