来自golang的经过身份验证的http客户端请求

前端之家收集整理的这篇文章主要介绍了来自golang的经过身份验证的http客户端请求前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
我有以下代码
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默认处理
req / client类。

我不得不使用的代码是:

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]
}

然后主要是:

jar := &myjar{}
    jar.jar = make(map[string] []*http.Cookie)
    client.Jar = jar

作品。

猜你在找的Go相关文章