Maison >développement back-end >Golang >Comment puis-je gérer efficacement les cookies dans les requêtes Go HTTP POST ?
Dans Go, la gestion des cookies est essentielle pour maintenir les sessions et accéder aux ressources protégées. Lors de l'exécution d'opérations HTTP POST, il est crucial de stocker les cookies pour les demandes ultérieures.
L'extrait de code fourni tente de se connecter à un site Web, de stocker des cookies et de les utiliser pour afficher une facture. Une amélioration potentielle consiste à utiliser le package cookiejar introduit dans Go 1.1.
Le package cookiejar fournit un moyen pratique de gérer les cookies pour les demandes des clients. Voici comment l'intégrer dans le code :
import ( "net/http" "net/http/cookiejar" ) jar, err := cookiejar.New(nil) if err != nil { // Error handling } client := &http.Client{ Jar: jar, }
En utilisant le pot dans le cadre du http.Client, les cookies seront automatiquement stockés et envoyés avec les requêtes ultérieures.
Le code mis à jour pour publier un formulaire, stocker des cookies et consulter une facture :
func Login(user, password string, client *http.Client) string { postUrl := "http://www.pge.com/eum/login" // Set up Login values := make(url.Values) values.Set("user", user) values.Set("password", password) // Submit form resp, err := client.PostForm(postUrl, values) if err != nil { log.Fatal(err) } defer resp.Body.Close() return "Hello" } func ViewBill(url string, client *http.Client) string { // Make the request using the client with cookies resp, err := client.Get(url) if err != nil { log.Fatal(err) } defer resp.Body.Close() return resp.Body }
Dans cette mise à jour version, l'objet client est passé en paramètre aux fonctions Login et ViewBill. Cela garantit que le même client est utilisé pour les deux opérations, préservant ainsi les cookies.
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!