使用net/http发送HTTP请求需先创建请求对象,设置方法、头信息及超时控制。1. 发起GET请求用http.Get并关闭响应体;2. POST等请求使用http.NewRequest配置Header和Body;3. 自定义Client设置超时与Transport提升稳定性;4. 响应处理需检查错误与状态码,始终关闭Body。合理封装可实现高效可靠的HTTP通信。

在Go语言中,net/http 包是处理HTTP请求和响应的核心工具。无论是构建客户端发送请求,还是编写服务端处理请求,它都提供了简洁而强大的接口。本文聚焦于如何使用 Golang 的 net/http 发送 HTTP 请求,并结合实际场景给出可复用的实践方法。
发起基本的GET请求
最简单的HTTP请求是GET请求,用于从服务器获取数据。使用 http.Get 可以快速实现:
resp, err := http.Get("https://api.example.com/data")
if err != nil {
log.Fatal(err)
}
defer resp.Body.Close()
body, _ := io.ReadAll(resp.Body)
fmt.Println(string(body))
这段代码发送一个GET请求,读取响应体并打印。注意一定要调用 resp.Body.Close() 避免资源泄露。
自定义请求(POST/PUT等)与设置头信息
对于需要设置请求方法、Header 或发送数据的场景,应使用 http.NewRequest 构造请求:
立即学习“go语言免费学习笔记(深入)”;
- 创建可配置的请求对象
- 手动设置 Header,如 Content-Type、Authorization
- 通过 Body 发送 JSON 或表单数据
示例:发送JSON格式的POST请求
data := map[string]string{"name": "Alice", "age": "25"}
jsonData, _ := json.Marshal(data)
req, _ := http.NewRequest("POST", "https://www.php.cn/link/93a819cbd635bd1505ef0f804c21cc2a", bytes.NewBuffer(jsonData))
req.Header.Set("Content-Type", "application/json")
req.Header.Set("Authorization", "Bearer token123")
client := &http.Client{}
resp, err := client.Do(req)
if err != nil {
log.Fatal(err)
}
defer resp.Body.Close()
使用自定义Client控制超时和重试
默认的 http.DefaultClient 没有设置超时,生产环境容易导致连接堆积。建议创建带超时的自定义 Client:
client := &http.Client{
Timeout: 10 * time.Second,
}
更进一步,可以配置 Transport 来控制连接复用、TLS 设置等:
client := &http.Client{
Transport: &http.Transport{
MaxIdleConns: 100,
IdleConnTimeout: 30 * time.Second,
TLSHandshakeTimeout: 5 * time.Second,
},
Timeout: 15 * time.Second,
}
这样能提升性能并避免常见网络问题。
处理响应与错误的健壮方式
真实的网络请求可能失败,需妥善处理各种情况:
- 检查 err 是否为网络错误(如连接超时、DNS失败)
- 即使返回 resp,也要判断 resp.StatusCode 是否为预期值
- 始终关闭 resp.Body,哪怕出错
推荐模式:
resp, err := client.Do(req)
if err != nil {
log.Printf("请求失败: %v", err)
return
}
defer resp.Body.Close()
if resp.StatusCode != http.StatusOK {
log.Printf("非预期状态码: %d", resp.StatusCode)
return
}
body, _ := io.ReadAll(resp.Body)
// 处理 body 数据
基本上就这些。net/http 虽然简单,但配合合理的封装和错误处理,足以应对大多数HTTP通信需求。不复杂但容易忽略细节,比如超时和连接管理,正是稳定性的关键所在。










