Go语言处理网络请求错误需检查error值并区分连接错误与状态码错误;2. 使用http.Get或Client.Do后必须检查err,处理超时、DNS解析等底层问题;3. 即使err为nil,也需判断resp.StatusCode是否为2xx,非2xx需读取body并记录错误;4. 应设置http.Client.Timeout避免阻塞,建议5秒左右;5. 只要resp不为nil,必须defer resp.Body.Close()防止资源泄露。

Go语言处理网络请求错误主要依赖net/http包和对返回值的严谨检查。关键在于始终检查error值,并理解不同阶段可能发生的错误类型。
检查HTTP请求基础错误
发起请求时,http.Get、http.Post或使用http.Client.Do都可能返回错误。这类错误通常是连接失败、DNS解析失败、超时等底层网络问题。
这类错误发生在请求未完成或无法发送时,不会包含HTTP响应。
- 确保每次调用
http.Do()后立即检查err != nil - 若出错,直接处理网络异常,不要尝试读取
resp - 常见错误包括: timeout, connection refused, no such host
示例:
立即学习“go语言免费学习笔记(深入)”;
resp, err := http.Get("https://example.com")
if err != nil {
log.Printf("请求失败: %v", err)
return
}
defer resp.Body.Close()
处理非2xx的HTTP状态码
即使err为nil,服务器仍可能返回404、500等错误状态。Go不会自动将这些视为错误,需手动判断resp.StatusCode。
- 使用
resp.StatusCode判断是否在200-299范围内 - 可借助
httputil.DumpResponse调试响应内容 - 对于API调用,建议封装统一的状态码检查逻辑
示例:
立即学习“go语言免费学习笔记(深入)”;
if resp.StatusCode < 200 || resp.StatusCode >= 300 {
body, _ := io.ReadAll(resp.Body)
log.Printf("HTTP错误 %d: %s", resp.StatusCode, string(body))
return
}
设置超时避免阻塞
默认的http.Client没有超时,可能导致程序长时间挂起。应配置合理的超时时间。
- 设置
Client.Timeout控制整个请求的最大耗时 - 更精细控制可用自定义
Transport设置DialTimeout、TLSHandshakeTimeout等 - 生产环境建议设置3-10秒的总超时
示例:
立即学习“go语言免费学习笔记(深入)”;
client := &http.Client{
Timeout: 5 * time.Second,
}
resp, err := client.Get("https://api.example.com/data")
正确关闭响应体
无论请求成功或失败,只要*http.Response存在(即err == nil),就必须调用resp.Body.Close(),否则会泄露文件描述符。
即使状态码是400或500,也需关闭Body。
- 使用
defer resp.Body.Close()确保释放资源 - 如果提前返回,确保Close仍会被执行
- 读取Body后也应关闭,防止连接无法复用
基本上就这些。Go的错误处理强调显式判断,网络请求尤其要注意区分连接错误和业务错误,同时做好资源清理和超时控制。










