来自golang的经过身份验证的http客户端请求
发布时间:2020-12-16 18:22:05 所属栏目:大数据 来源:网络整理
导读:我有以下代码: 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)}
|
我有以下代码:
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访问被拒绝的错误。一个不同的REST客户端(一个firefox插件)正确地从服务器获取了详细信息,所以我知道在服务器端没有任何错误。我需要传递某种类型的会话字符串吗?
好的。我已经解决了这个问题。我只需要创建一个cookie jar。
我很惊讶,这不是由golang http默认处理 我不得不使用的代码是: type myjar struct {
jar map[string] []*http.Cookie
}
func (p* myjar) SetCookies(u *url.URL,cookies []*http.Cookie) {
fmt.Printf("The URL is : %sn",u.String())
fmt.Printf("The cookie being set is : %sn",cookies)
p.jar [u.Host] = cookies
}
func (p *myjar) Cookies(u *url.URL) []*http.Cookie {
fmt.Printf("The URL is : %sn",u.String())
fmt.Printf("Cookie being returned is : %sn",p.jar[u.Host])
return p.jar[u.Host]
}
然后主要是: jar := &myjar{}
jar.jar = make(map[string] []*http.Cookie)
client.Jar = jar
作品。 (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |
