Heim > Backend-Entwicklung > Golang > Wie gehe ich mit Authentifizierungscookies für HTTP-Anfragen in Go um?

Wie gehe ich mit Authentifizierungscookies für HTTP-Anfragen in Go um?

DDD
Freigeben: 2024-11-08 22:56:02
Original
520 Leute haben es durchsucht

How to Handle Authentication Cookies for HTTP Requests in Go?

Verbesserung der Authentifizierungsbehandlung für HTTP-Abfragen in Go

Problem:

Bedenken Sie den folgenden Code zum Durchführen von HTTP-Anfragen mit Authentifizierung:

client := &http.Client{}

// Authenticate
req, err := http.NewRequest("GET", "http://164.99.113.32/Authenticate", nil)
req.SetBasicAuth("<username>", "<password>")
resp, err := client.Do(req)
if err != nil {
    fmt.Printf("Error : %s", err)
}

// Get Details
req.URL, _ = url.Parse("http://164.99.113.32/Details")
resp, err = client.Do(req)
if err != nil {
    fmt.Printf("Error : %s", err)
}
Nach dem Login kopieren

Nach erfolgreicher Authentifizierung schlägt die nachfolgende Anfrage an „/Details“ mit der Fehlermeldung 401 „Zugriff verweigert“ fehl, obwohl auf der Serverseite kein Problem vorliegt.

Lösung:

Um dieses Problem zu beheben, ist es notwendig, eine Cookie-Dose zu verwenden, um Sitzungsinformationen zu verwalten. Der HTTP-Client von Go verarbeitet dies standardmäßig nicht, daher müssen wir unsere benutzerdefinierte Cookie-Jar-Implementierung definieren:

type myjar struct {
    jar map[string] []*http.Cookie
}

func (p* myjar) SetCookies(u *url.URL, cookies []*http.Cookie) {
    fmt.Printf("The URL is : %s\n", u.String())
    fmt.Printf("The cookie being set is : %s\n", cookies)
    p.jar [u.Host] = cookies
}

func (p *myjar) Cookies(u *url.URL) []*http.Cookie {
    fmt.Printf("The URL is : %s\n", u.String())
    fmt.Printf("Cookie being returned is : %s\n", p.jar[u.Host])
    return p.jar[u.Host]
}
Nach dem Login kopieren

Initialisieren Sie in der Hauptfunktion die benutzerdefinierte Cookie-Jar und weisen Sie sie dem HTTP-Client zu:

    jar := &myjar{}
    jar.jar = make(map[string] []*http.Cookie)
    client.Jar = jar
Nach dem Login kopieren

Mit dieser Implementierung kann die nachfolgende Anfrage erfolgreich auf den Endpunkt „/Details“ zugreifen.

Das obige ist der detaillierte Inhalt vonWie gehe ich mit Authentifizierungscookies für HTTP-Anfragen in Go um?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Quelle:php.cn
Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage