Heim >Backend-Entwicklung >Golang >Warum schlägt die einfache HTTP-Authentifizierung in Go fehl, wenn Weiterleitungen auftreten?
Grundlegende HTTP-Authentifizierungsverarbeitung in Go
Bei der Implementierung der grundlegenden HTTP-Authentifizierung in Go können einige unerwartete Herausforderungen auftreten. Dieser Artikel befasst sich mit einem häufigen Problem, das beim Versuch auftritt, die grundlegende HTTP-Authentifizierung zu implementieren.
Problem: Beim Ausführen des folgenden Codes tritt ein Fehler mit der Meldung „nicht unterstütztes Protokollschema“ auf:
func basicAuth() string { var username string = "foo" var passwd string = "bar" client := &http.Client{} req, err := http.NewRequest("GET", "mydomain.example", nil) req.SetBasicAuth(username, passwd) resp, err := client.Do(req) if err != nil{ log.Fatal(err) } bodyText, err := ioutil.ReadAll(resp.Body) s := string(bodyText) return s }
Ursache: Wenn Weiterleitungen auftreten, verwirft Go-lang alle angegebenen Header, einschließlich der Autorisierung Header für Basisauthentifizierung festgelegt.
Lösung:Um dieses Problem zu beheben, kann eine benutzerdefinierte Umleitungsrichtlinienfunktion implementiert werden:
func redirectPolicyFunc(req *http.Request, via []*http.Request) error { req.Header.Add("Authorization", "Basic "+basicAuth("username1", "password123")) return nil }
Diese Funktion stellt sicher, dass der Autorisierungsheader wird bei Weiterleitungen wieder hinzugefügt, wodurch die Authentifizierung effektiv erhalten bleibt Anmeldeinformationen.
Implementierung:
func main() { client := &http.Client{ Jar: cookieJar, CheckRedirect: redirectPolicyFunc, } req, err := http.NewRequest("GET", "http://localhost/", nil) req.Header.Add("Authorization", "Basic "+basicAuth("username1", "password123")) resp, err := client.Do(req) }
Durch die Verwendung der Weiterleitungsrichtlinienfunktion bleiben die angegebenen Header, einschließlich des Autorisierungsheaders für die Basisauthentifizierung, während der Weiterleitungen bestehen, wodurch sichergestellt wird Erfolgreiche Authentifizierung beim Zielserver.
Das obige ist der detaillierte Inhalt vonWarum schlägt die einfache HTTP-Authentifizierung in Go fehl, wenn Weiterleitungen auftreten?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!