33

我有以下代码:

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 插件)正确地从服务器获取详细信息,所以我知道服务器端没有任何问题。我是否需要传递某种会话字符串或我们在上一个请求中得到的东西?

4

3 回答 3

24

好的。我已经解决了这个问题。我只需要创建一个饼干罐。

我很惊讶 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

作品。

于 2012-07-06T13:55:17.887 回答
13

使用 HTTP 基本身份验证,每个请求都需要凭据。尝试复制

req.SetBasicAuth("<username>", "<password>")

在第二个 client.Do(req) 之前的行。

Firefox 插件获取详细信息的原因是浏览器将缓存 HTTP 基本身份验证令牌以供后续使用。

于 2012-07-06T13:37:49.517 回答
4

有一个新的官方图书馆,也许这很有帮助。

http://golang.org/pkg/net/http/cookiejar/

示例: Golang:如何使用 cookie 跟踪位置

于 2014-07-21T02:23:08.050 回答