我想记录301s vs 302s,但看不到在Client.Do,Get,doFollowingRedirects,CheckRedirect中读取响应状态代码的方法。我是否必须自己实现重定向才能实现这一目标?
答案 0 :(得分:11)
http.Client
类型允许您指定自定义传输,这样您就可以执行自己之后的操作。类似下面的事情应该做:
type LogRedirects struct {
Transport http.RoundTripper
}
func (l LogRedirects) RoundTrip(req *http.Request) (resp *http.Response, err error) {
t := l.Transport
if t == nil {
t = http.DefaultTransport
}
resp, err = t.RoundTrip(req)
if err != nil {
return
}
switch resp.StatusCode {
case http.StatusMovedPermanently, http.StatusFound, http.StatusSeeOther, http.StatusTemporaryRedirect:
log.Println("Request for", req.URL, "redirected with status", resp.StatusCode)
}
return
}
(如果你只支持链接到默认传输,你可以稍微简化一下)。
然后,您可以使用此传输创建客户端,并且应记录所有重定向:
client := &http.Client{Transport: LogRedirects{}}
以下是您可以试验的完整示例:http://play.golang.org/p/8uf8Cn31HC