Go에서 HTTP 쿼리에 대한 인증 처리 개선
문제:
다음 코드를 고려하세요. HTTP 요청을 수행하기 위해 인증:
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) }
인증에 성공한 후 서버 측에 문제가 없음에도 불구하고 '/Details'에 대한 후속 요청이 401 액세스 거부 오류와 함께 실패합니다.
해결책:
이를 해결하려면 쿠키 용기를 활용하여 세션 정보를 관리해야 합니다. Go의 HTTP 클라이언트는 기본적으로 이를 처리하지 않으므로 사용자 정의 쿠키 jar 구현을 정의해야 합니다.
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] }
메인 함수에서 사용자 정의 쿠키 jar를 초기화하고 이를 HTTP 클라이언트에 할당합니다.
jar := &myjar{} jar.jar = make(map[string] []*http.Cookie) client.Jar = jar
이 구현을 통해 후속 요청은 '/Details' 엔드포인트에 성공적으로 액세스할 수 있습니다.
위 내용은 Go에서 HTTP 요청에 대한 인증 쿠키를 처리하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!