Permintaan Pelanggan HTTP Disahkan daripada Go
Pertimbangkan coretan kod berikut:
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) }
Masalahnya di sini ialah panggilan HTTP kedua gagal dengan akses 401 ditolak ralat.
Mengapa ini berlaku?
Sebabnya permintaan kedua tidak mengandungi kuki sesi yang diperoleh semasa permintaan pertama. Untuk menyelesaikannya, kita perlu mencipta balang kuki untuk menyimpan dan menggunakan semula kuki merentas permintaan.
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] }
Dalam fungsi utama:
jar := &myjar{} jar.jar = make(map[string] []*http.Cookie) client.Jar = jar
Dengan perubahan ini, permintaan kedua akan mempunyai kuki yang diperlukan untuk berjaya mengesahkan dan mendapatkan butiran daripada pelayan.
Atas ialah kandungan terperinci Bagaimanakah saya boleh mengesahkan permintaan HTTP seterusnya dalam Go selepas pengesahan awal menggunakan pengesahan asas?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!