>백엔드 개발 >Golang >Go에서 HTTP 요청에 대한 인증 쿠키를 처리하는 방법은 무엇입니까?

Go에서 HTTP 요청에 대한 인증 쿠키를 처리하는 방법은 무엇입니까?

DDD
DDD원래의
2024-11-08 22:56:02535검색

How to Handle Authentication Cookies for HTTP Requests in Go?

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 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.