我正在研究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]
。
在邮递员中执行相同的请求时
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
(这是我需要针对服务器进行身份验证的令牌) )。
我不确定自己在做什么,为什么在使用Golang代码调用端点时为什么看不到au
Cookie。
有猜到吗?
答案 0 :(得分:1)
您可能具有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的概述中,您有一个有关如何控制重定向策略的示例。
祝你好运。