答案:使用Golang发起HTTP请求时需显式检查error,区分网络错误与HTTP状态码错误,确保资源释放。首先在http.NewRequest和client.Do阶段处理URL格式、网络连接等错误;即使resp非nil也需读取并关闭Body;4xx/5xx状态码不属于error,须手动判断StatusCode;通过类型断言识别*url.Error中的超时或临时错误以支持重试;始终defer resp.Body.Close()防止泄漏;自定义函数应封装错误并向上返回,统一处理。

在使用 Golang 发起 HTTP 客户端请求时,正确捕获和处理错误是确保程序健壮性的关键。Go 的 net/http 包本身不会主动抛出异常,而是通过返回 error 类型来传递问题信息。因此,必须显式检查每次请求的返回值。
HTTP 请求过程分为多个步骤,每个步骤都可能出错,需要分别处理:
resp, err := http.Get("https://invalid-url./")
if err != nil {
log.Printf("请求失败: %v", err)
return
}
defer resp.Body.Close()
// 注意:404 或 500 等状态码不会触发 err,需手动判断
if resp.StatusCode >= 400 {
log.Printf("HTTP 错误状态: %d", resp.StatusCode)
}
error 不等于 HTTP 状态错误。比如连接超时、TLS 握手失败属于网络层错误,而 404、500 是服务端返回的业务逻辑错误。
if uerr, ok := err.(*url.Error); ok {
if uerr.Timeout() {
log.Println("请求超时")
} else if uerr.Temporary() {
log.Println("临时性错误,可尝试重试")
}
}
即使发生错误,也要注意避免资源泄漏。例如 resp.Body 必须关闭,即使 StatusCode 异常。
立即学习“go语言免费学习笔记(深入)”;
func fetch(url string) ([]byte, error) {
resp, err := http.Get(url)
if err != nil {
return nil, fmt.Errorf("请求失败: %w", err)
}
defer resp.Body.Close()
body, err := io.ReadAll(resp.Body)
if err != nil {
return nil, fmt.Errorf("读取响应失败: %w", err)
}
if resp.StatusCode != 200 {
return nil, fmt.Errorf("HTTP 状态错误: %d", resp.StatusCode)
}
return body, nil
}
以上就是Golang HTTP客户端请求错误如何捕获的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号