시스템 자격 증명을 사용하여 Go HTTP 요청에서 NTLM 인증
사용자의 시스템 자격 증명을 활용하면 Go HTTP 요청에서 NTLM 인증을 단순화할 수 있습니다. . C# 및 Python과 같은 다른 언어에서는 내장 라이브러리를 사용하여 이를 달성할 수 있습니다.
Go에서 시스템 자격 증명으로 NTLM 인증을 수행하려면 go-ole 패키지를 활용할 수 있습니다. 이 패키지를 사용하면 WinHTTPRequest 개체를 포함한 COM(구성 요소 개체 모델) 개체와 상호 작용할 수 있습니다.
이를 달성하는 방법을 보여주는 코드 조각은 다음과 같습니다.
<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 개체와 AutoLogonPolicy를 0으로 설정하면 시스템 자격 증명이 HTTP 요청에 자동으로 적용됩니다. 이 접근 방식은 Go에서 NTLM 인증을 단순화하여 사용자 이름과 비밀번호 자격 증명을 명시적으로 제공하지 않고도 요청할 수 있도록 해줍니다.
위 내용은 Go HTTP 요청에서 NTLM 인증을 위해 시스템 자격 증명을 어떻게 사용할 수 있나요?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!