Go에서 HTTP 요청에 대한 인증과 함께 프록시 사용
HTTP 요청 작업을 할 때 인증을 통한 프록시. 이는 네트워크 제한 때문이거나 성능 향상 때문일 수 있습니다. 그러나 Go에서는 인증을 사용하여 프록시를 설정하는 것이 약간 까다로울 수 있습니다.
net/http 패키지(Go에서 HTTP 요청을 처리하기 위한 표준 라이브러리 패키지)에 대한 문서는 프록시 사용 방법에 대한 예를 제공하지만 인증된 프록시의 경우를 명시적으로 다루지 않습니다. 이를 처리하려면 프록시 요청을 올바르게 승인하도록 전송에서 HEADER를 설정해야 합니다.
Go에서 net/http 패키지를 사용하여 HTTP 요청에서 인증과 함께 프록시를 사용할 수 있는 방법은 다음과 같습니다.
인증 자격 증명을 선언합니다. 프록시에 대한 사용자 이름과 비밀번호를 선언하여 시작합니다. 인증.
auth := "username:password"
자격 증명을 인코딩합니다. base64 인코딩을 사용하여 자격 증명을 인코딩합니다.
basicAuth := "Basic " base64.StdEncoding.EncodeToString([]byte(auth))
ProxyConnectHeader 설정: http.Header를 생성하여 프록시 인증 헤더를 보관하고 인코딩된 헤더를 추가합니다. 자격 증명.
transport.ProxyConnectHeader = http.Header{}
transport.ProxyConnectHeader.Add("Proxy-Authorization", basicAuth)
전송 사용: HTTP 요청에 수정된 전송을 사용합니다.
client := &http.Client{
Transport: transport,
}
이 단계를 따르면 Go의 HTTP 요청에서 인증을 통해 프록시를 성공적으로 사용할 수 있습니다.
부인 성명: 제공된 모든 리소스는 부분적으로 인터넷에서 가져온 것입니다. 귀하의 저작권이나 기타 권리 및 이익이 침해된 경우 자세한 이유를 설명하고 저작권 또는 권리 및 이익에 대한 증거를 제공한 후 이메일([email protected])로 보내주십시오. 최대한 빨리 처리해 드리겠습니다.
Copyright© 2022 湘ICP备2022001581号-3