Maison >développement back-end >Golang >Comment puis-je gérer efficacement les cookies dans les requêtes Go HTTP POST ?

Comment puis-je gérer efficacement les cookies dans les requêtes Go HTTP POST ?

Patricia Arquette
Patricia Arquetteoriginal
2024-12-22 22:43:13380parcourir

How Can I Effectively Manage Cookies in Go HTTP POST Requests?

Go HTTP Post et utilisation des cookies : un guide complet

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.

Utiliser cookiejar pour la gestion des cookies

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.

Code mis à jour avec Cookies

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!

Déclaration:
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn