我想记录301s vs 302s,但看不到在客户端读取响应状态代码的方法。Do, Get, doFollowingRedirects, CheckRedirect。我必须自己实现重定向来实现这一点吗?
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