In Go ist die Verwaltung von Cookies für die Aufrechterhaltung von Sitzungen und den Zugriff auf geschützte Ressourcen unerlässlich. Bei der Durchführung von HTTP-POST-Vorgängen ist es wichtig, Cookies für nachfolgende Anfragen zu speichern.
Das Code-Snippet stellte Versuche bereit, sich bei einer Website anzumelden, Cookies zu speichern und sie zum Anzeigen einer Rechnung zu verwenden. Eine mögliche Verbesserung ist die Verwendung des in Go 1.1 eingeführten Cookiejar-Pakets.
Das Cookiejar-Paket bietet eine praktische Möglichkeit, Cookies für Kundenanfragen zu verwalten. So integrieren Sie es in den Code:
import ( "net/http" "net/http/cookiejar" ) jar, err := cookiejar.New(nil) if err != nil { // Error handling } client := &http.Client{ Jar: jar, }
Durch die Verwendung des JAR als Teil des http.Client werden Cookies automatisch gespeichert und bei nachfolgenden Anfragen gesendet.
Der aktualisierte Code zum Versenden eines Formulars, zum Speichern von Cookies und zum Anzeigen einer Rechnung:
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 }
In dieser aktualisierten Version der Client Das Objekt wird als Parameter an die Funktionen Login und ViewBill übergeben. Dadurch wird sichergestellt, dass für beide Vorgänge derselbe Client verwendet wird und die Cookies erhalten bleiben.
Das obige ist der detaillierte Inhalt vonWie kann ich Cookies in Go-HTTP-POST-Anfragen effektiv verwalten?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!