Go默认自动处理HTTP重定向(最多10次),可通过CheckRedirect函数自定义逻辑:限制跳转次数、禁用重定向或阻止跨域跳转,via参数记录历史请求路径便于调试。

在Golang中处理HTTP重定向,关键在于理解客户端如何自动或手动控制重定向行为。默认情况下,Go的net/http包会自动处理重定向,但有时需要自定义逻辑,比如限制跳转次数、记录跳转路径或阻止某些重定向。
1. 默认的自动重定向机制
Go的http.Client默认启用了重定向策略。它使用DefaultClient中的CheckRedirect函数来决定是否允许重定向。
发送一个请求时,如果服务器返回301、302、307等状态码,客户端会自动跟随Location头进行跳转,最多默认10次,防止无限循环。
示例:发起一个自动重定向请求:
立即学习“go语言免费学习笔记(深入)”;
resp, err := http.Get("http://example.com/redirect")
if err != nil {
log.Fatal(err)
}
defer resp.Body.Close()
// 响应已经是最终目标页面
2. 自定义重定向策略
通过设置http.Client的CheckRedirect字段,可以完全控制重定向行为。
该函数接收当前请求和将要跳转的请求切片,返回错误来中断重定向,或返回nil继续。
示例:限制重定向次数为3次client := &http.Client{
CheckRedirect: func(req *http.Request, via []*http.Request) error {
if len(via) >= 3 {
return errors.New("stopped after 3 redirects")
}
return nil
},
}
resp, err := client.Do(http.NewRequest("GET", "http://example.com", nil))
if err != nil {
log.Fatal("Error:", err)
}
defer resp.Body.Close()
3. 禁用重定向
若希望禁用自动重定向,只需让CheckRedirect始终返回错误。
这样可以获取原始响应(如302状态码和Location头),用于分析跳转逻辑。
示例:禁止任何重定向client := &http.Client{
CheckRedirect: func(req *http.Request, via []*http.Request) error {
return http.ErrUseLastResponse // 使用最后一次非重定向响应
},
}
resp, err := client.Get("http://example.com/redirect")
if err != nil {
log.Fatal(err)
}
// 此时 resp 可能是 301 或 302 响应
fmt.Println("Status:", resp.Status)
fmt.Println("Location:", resp.Header.Get("Location"))
4. 处理相对路径与跨域重定向
重定向可能指向相对URL或不同域名。Go的客户端会自动处理相对路径转换,并默认允许跨域跳转。
若需阻止跨域重定向,可在CheckRedirect中比较域名:
CheckRedirect: func(req *http.Request, via []*http.Request) error {
if len(via) > 0 && via[0].URL.Host != req.URL.Host {
return errors.New("no cross-domain redirects")
}
return nil
},
基本上就这些。掌握http.Client的CheckRedirect机制,就能灵活应对各种重定向场景,无论是放行、限制还是完全关闭。不复杂但容易忽略细节,比如via参数包含历史请求顺序,可用于调试跳转路径。










