在Golang中处理HTTP错误需主动检查StatusCode,示例:发送请求后判断resp.StatusCode >= 400并记录错误详情,可定义HTTPError类型增强语义化,如404返回“资源未找到”,对503等错误实施重试机制,401则触发认证刷新,核心是手动处理状态码以实现健壮的错误响应。

在Golang中处理HTTP错误状态码,关键在于正确检查响应状态并根据状态码采取相应措施。Go的标准库net/http不会自动抛出异常,因此开发者必须手动判断和处理非200系列的状态码。
检查HTTP响应状态码
发送HTTP请求后,应始终检查*http.Response中的StatusCode字段。常见的错误范围是4xx(客户端错误)和5xx(服务器错误)。
示例代码:
resp, err := http.Get("https://api.example.com/data")
if err != nil {
log.Fatal("请求失败:", err)
}
defer resp.Body.Close()
if resp.StatusCode >= 400 {
log.Printf("HTTP错误: %d %s", resp.StatusCode, resp.Status)
// 可选择读取错误详情
body, _ := io.ReadAll(resp.Body)
log.Printf("响应体: %s", string(body))
}
使用自定义错误类型增强可读性
为不同状态码定义语义化错误,有助于上层逻辑判断。例如:
立即学习“go语言免费学习笔记(深入)”;
type HTTPError struct {
StatusCode int
Message string
}
func (e *HTTPError) Error() string {
return fmt.Sprintf("HTTP %d: %s", e.StatusCode, e.Message)
}
// 使用示例
if resp.StatusCode == 404 {
return nil, &HTTPError{StatusCode: 404, Message: "资源未找到"}
}
结合业务逻辑进行重试或降级
某些错误如503(服务不可用)可能适合重试,而401(未授权)则需要重新认证。
简单重试逻辑示例:
for i := 0; i < 3; i++ {
resp, err := http.Get(url)
if err != nil || resp.StatusCode >= 500 {
time.Sleep(time.Second * time.Duration(i+1))
continue
}
if resp.StatusCode == 401 {
// 触发token刷新
break
}
// 正常处理
break
}
基本上就这些。关键是不能忽略StatusCode,要主动判断,并根据场景返回合适错误或执行恢复动作。标准库的设计把控制权交给了开发者,灵活性高但也要求更严谨的错误处理习惯。










