HTTP POST et gestion des cookies dans Go
Lors de l'interaction avec des sites Web, le stockage de cookies est souvent nécessaire pour maintenir les sessions et suivre les préférences des utilisateurs. Dans Go, cela peut être réalisé en utilisant la structure http.Client et le package cookiejar introduits dans Go 1.1.
Considérez l'extrait de code suivant qui montre la publication d'un formulaire et le stockage des cookies associés :
import ( "net/http" "net/http/cookiejar" "net/url" ) func Login(user, password string) { postUrl := "http://www.example.com/login" // Set up login form data values := make(url.Values) values.Set("user", user) values.Set("password", password) // Create a cookie jar for storing cookies jar, err := cookiejar.New(nil) if err != nil { // Handle error } // Create an HTTP client with the cookie jar client := &http.Client{ Jar: jar, } // Submit the form using the client resp, err := client.PostForm(postUrl, values) if err != nil { // Handle error } defer resp.Body.Close() // Cookies are now stored in the cookie jar }
Après vous être connecté, vous pouvez accéder à d'autres pages en utilisant le même client, qui enverra automatiquement les cookies stockés dans les prochaines étapes. requêtes :
func ViewBill(url string) { // Assuming the client with the cookie jar is already created resp, err := client.Get(url) if err != nil { // Handle error } defer resp.Body.Close() // The stored cookies will be used automatically for this request }
En utilisant le package cookiejar et la structure http.Client, vous pouvez facilement gérer les cookies et maintenir des sessions dans Go lorsque vous interagissez avec des sites Web qui nécessitent une authentification et un suivi de session basé sur 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!