Lors du traitement des requêtes HTTP, il est courant de rencontrer des redirections qui transportent des cookies. Cela pose un défi lors de l'utilisation de Golang, car le comportement par défaut consiste à supprimer les cookies lors des redirections. Pour surmonter ce problème, vous pouvez utiliser le package net/http/cookiejar, introduit dans Go 1.1.
Avec le package cookiejar, vous pouvez configurer un client pour qu'il suive automatiquement les redirections tout en préservant les cookies reçus. Pour y parvenir :
Voici un exemple illustratif :
<code class="go">package main import ( "golang.org/x/net/publicsuffix" "io/ioutil" "log" "net/http" "net/http/cookiejar" ) func main() { options := cookiejar.Options{ PublicSuffixList: publicsuffix.List, } jar, err := cookiejar.New(&options) if err != nil { log.Fatal(err) } client := http.Client{Jar: jar} resp, err := client.Get("http://dubbelboer.com/302cookie.php") if err != nil { log.Fatal(err) } data, err := ioutil.ReadAll(resp.Body) resp.Body.Close() if err != nil { log.Fatal(err) } log.Println(string(data)) }</code>
En utilisant cette approche, votre client Go suivra automatiquement les redirections et maintiendra les redirections reçues. cookies, similaire au comportement dans cURL lors de la configuration de COOKIEFILE, AUTOREFERER et FOLLOWLOCATION.
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!