我正在研究 Golang,我正试图达到一个终点(我无法控制)。
这是我写的代码:
params := url.Values{}
params.Add("data[User][username]", <THE_USERNAME>)
params.Add("data[User][password]", <THE_PASSWORD>)
resp, _ := http.PostForm(<LOGIN_URL>, params)
fmt.Println(resp.Cookies())
Println
版画 [PHPSESSID=<ID>; Path=/; HttpOnly]
.
在 Postman 中做同样的请求时
POST /login HTTP/1.1
Host: <HOST>
Content-Type: application/x-www-form-urlencoded
Cache-Control: no-cache
Postman-Token: 399a42af-00f2-4340-b7fa-1ae1fa295b62
<PARAM_DATA>
我可以看到响应中设置了两个 cookie,PHPSESSID
(我猜这在 Golang 中是一样的)和 au
(这是我需要的 token ,以便针对服务器进行身份验证)。
我不确定我做错了什么以及为什么我看不到 au
使用 Golang 代码调用端点时的 Cookie。
有什么猜测吗?
最佳答案
您可能有 HTTP 重定向(302 或 301)。
试试这个:
package main
import (
"log"
"net/http"
"net/url"
)
func main() {
params := url.Values{}
params.Add("data[User][username]", "test")
params.Add("data[User][password]", "test")
client := &http.Client{
CheckRedirect: func(req *http.Request, via []*http.Request) error {
return http.ErrUseLastResponse
},
}
resp, err := client.PostForm("http://example.com", params)
if err != nil {
log.Fatal(err)
}
log.Println(resp.Cookies())
}
在 net/http 包的概述中 documentation你有一个关于如何控制重定向策略的例子。
祝你好运。
关于http - Golang http.PostParam 未在响应中显示所有 Cookie,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/51528092/