来自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 作品。 (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |