Go의 HTTP 기본 인증: 일반적인 오류 문제 해결
제공된 코드를 사용하여 기본 HTTP 인증을 구현하려고 시도하는 동안 오류가 발생합니다. "지원되지 않는 프로토콜 구성표 ''". 이는 요청 개체를 생성할 때 코드에 실수가 있었던 것으로 추적될 수 있습니다.
이 오류를 해결하려면 요청 URL에 올바른 구성표가 지정되어 있는지 확인하세요. 주어진 예에서는 프로토콜 체계를 지정하지 않고 "mydomain.example"에 요청을 시도하여 오류가 발생합니다.
이를 수정하려면 다음과 같이 HTTPS 체계를 명시적으로 지정하도록 코드를 수정하세요.
req, err := http.NewRequest("GET", "https://mydomain.example", nil)
또한 Go의 HTTP 클라이언트가 리디렉션을 처리할 때 또 다른 문제에 직면할 수 있다는 점도 주목할 가치가 있습니다. 기본적으로 클라이언트는 리디렉션 중에 기본 인증 헤더를 포함한 사용자 정의 헤더를 유지하지 않습니다.
이 동작을 우회하려면 리디렉션 중에 인증 헤더를 명시적으로 다시 추가하는 사용자 정의 리디렉션 정책 기능을 정의할 수 있습니다. 이렇게 하면 리디렉션 프로세스 전반에 걸쳐 인증 자격 증명이 보존됩니다.
다음은 사용자 정의 리디렉션 정책 기능의 예입니다.
func redirectPolicyFunc(req *http.Request, via []*http.Request) error { req.Header.Add("Authorization", "Basic " + basicAuth(username, password)) return nil }
HTTP 클라이언트에서 이 사용자 정의 정책을 사용하면 다음을 보장할 수 있습니다. 리디렉션 중에 기본 인증 헤더가 올바르게 처리되어 원활한 인증이 가능합니다.
위 내용은 Go 기본 인증에서 '지원되지 않는 프로토콜 구성표 ''' 오류를 수정하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!