我有以下代码:
client := &http.Client{}
/* Authenticate */
req, err := http.NewRequest("GET", "http://164.99.113.32/Authenticate", nil)
req.SetBasicAuth("<username>","<password>")
resp, err := client.Do(req)
if err != nil {
fmt.Printf("Error : %s", err)
}
/* Get Details */
req.URL, _ = url.Parse("http://164.99.113.32/Details")
resp, err = client.Do(req)
if err != nil {
fmt.Printf("Error : %s", err)
}
现在,第二个http调用失败,出现401 access-denied错误。一个不同的REST客户端(一个firefox插件)正确地从服务器获取详细信息,所以我知道服务器端没有任何问题。我是否需要传递某种会话字符串或我们在之前的请求中获得的内容?
答案 0 :(得分:20)
好。我已经解决了这个问题我只需要创建一个饼干罐。
我很惊讶golang http默认不处理这个问题 req / client class。
我必须使用的代码是:
type myjar struct {
jar map[string] []*http.Cookie
}
func (p* myjar) SetCookies(u *url.URL, cookies []*http.Cookie) {
fmt.Printf("The URL is : %s\n", u.String())
fmt.Printf("The cookie being set is : %s\n", cookies)
p.jar [u.Host] = cookies
}
func (p *myjar) Cookies(u *url.URL) []*http.Cookie {
fmt.Printf("The URL is : %s\n", u.String())
fmt.Printf("Cookie being returned is : %s\n", p.jar[u.Host])
return p.jar[u.Host]
}
然后在main:
jar := &myjar{}
jar.jar = make(map[string] []*http.Cookie)
client.Jar = jar
作品。
答案 1 :(得分:12)
使用HTTP基本身份验证时,每个请求都需要凭据。尝试复制
req.SetBasicAuth("<username>", "<password>")
在第二个client.Do(req)之前排队。
Firefox插件获取详细信息的原因是浏览器将缓存HTTP Basic 身份验证令牌以供后续使用。
答案 2 :(得分:4)
有一个新的官方图书馆,也许这很有帮助。