>백엔드 개발 >Golang >Go 기본 인증에서 '지원되지 않는 프로토콜 구성표 ''' 오류를 수정하는 방법은 무엇입니까?

Go 기본 인증에서 '지원되지 않는 프로토콜 구성표 ''' 오류를 수정하는 방법은 무엇입니까?

Barbara Streisand
Barbara Streisand원래의
2024-11-24 03:24:10972검색

How to Fix

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

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