시스템 자격 증명을 사용하여 Go HTTP 요청의 NTLM 인증
이 질문에서 사용자는 Go HTTP에서 Windows NTML 인증을 수행하는 방법에 대한 지침을 구합니다. 호출 사용자의 시스템 자격 증명을 사용하여 요청합니다. 해당 언어에서 이를 달성하는 방법을 보여주는 C# 및 Python의 예제를 제공합니다.
해결책은 Go에서 WinHTTPRequest를 사용할 수 있게 해주는 go-ole 라이브러리를 활용하는 데 있습니다. Python 예제와 유사한 접근 방식을 따르면 Go에서 시스템 자격 증명을 사용하여 NTML 인증을 구현할 수 있습니다.
이를 수행하기 위해 Go에서 제공되는 코드 조각은 다음과 같습니다.
<code class="go">package main import ( "fmt" ole "github.com/go-ole/go-ole" "github.com/go-ole/go-ole/oleutil" ) func main() { ole.CoInitialize(0) defer ole.CoUninitialize() unknown, _ := oleutil.CreateObject("WinHTTP.WinHTTPRequest.5.1") request, _ := unknown.QueryInterface(ole.IID_IDispatch) oleutil.CallMethod(request, "SetAutoLogonPolicy", 0) oleutil.CallMethod(request, "Open", "GET", "http://example.com", false) oleutil.CallMethod(request, "Send") resp := oleutil.MustGetProperty(request, "ResponseText") fmt.Println(resp.ToString()) }</code>
이 코드는 WinHTTPRequest 개체를 초기화하고, 현재 사용자의 자격 증명을 사용하도록 자동 로그온 정책을 설정하고, 지정된 URL에 대한 GET 요청을 열고, 요청을 보내고, 응답 텍스트를 검색합니다.
위 내용은 시스템 자격 증명을 사용하여 Go HTTP 요청에서 NTLM 인증을 수행하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!