根据您的问题,我认为您已经很清楚了,但以防万一:
会话未在客户端启动,而是在服务器上启动。服务器检查是否存在特定的cookie;如果是,它会恢复 cookie 识别的会话;如果不是,它会创建一个新会话并将标识符作为 cookie 发送回客户端。客户端需要做的就是将正确的 cookie 发送到服务器。
所以,你需要读写cookies。该fasthttp.Client.Post()界面不允许您这样做。所以不是那个漂亮的界面,事情变得相当丑陋。
在发出请求之前,您需要同时请求fasthttpaRequest和Responseobject。完成初始请求后,您需要查看所有 cookie,或读出特定 cookie。您现在可以将这些值用于下一个请求。
我写了一个简短的例子来说明你将如何做到这一点。
func main() {
c := fasthttp.Client{}
// Create a request
req := fasthttp.AcquireRequest()
defer fasthttp.ReleaseRequest(req)
req.SetRequestURI(`https://www.google.com/`)
// Create a response
resp := fasthttp.AcquireResponse()
defer fasthttp.ReleaseResponse(resp)
// Execute the request, writing to the response object
err := c.Do(req, resp)
if err != nil {
panic(err)
}
// Loop over all cookies; usefull if you want to just send everything back on consecutive requests
resp.Header.VisitAllCookie(func(key, value []byte) {
log.Printf("Cookie %s: %s\n", key, value)
})
// Read a specific cookie
nid := fasthttp.AcquireCookie()
defer fasthttp.ReleaseCookie(nid)
nid.SetKey(`NID`)
if resp.Header.Cookie(nid) {
log.Println("Value for NID Cookie: " + string(nid.Value()))
// Create a second request and set the cookie from the first
req2 := fasthttp.AcquireRequest()
defer fasthttp.ReleaseRequest(req2)
req2.SetRequestURI(`https://www.google.com/`)
req2.Header.SetCookie(`NID`, string(nid.Value()))
// Now you can execute this request again using c.Do() - don't forget to acquire a new Response!
}
}
注意:您可以选择跳过fasthttp.AcquireXXX()anddefer fasthttp.ReleaseXXX(yyy)步骤 - 但这会抵消使用 standard 的很多(可能是大部分)性能优势net/http,所以如果你走这条路,可能只是fasthttp一起放弃。