Go HTTP 요청에서 시스템 자격 증명을 사용한 NTLM 인증
개발자로서 HTTP 요청을 수행하고 인증해야 하는 시나리오에 직면할 수 있습니다. 애플리케이션을 실행하는 사용자의 시스템 자격 증명을 사용합니다. Windows 환경에서는 NTLM(Negotiate Token Level Message) 인증을 사용하여 이를 수행할 수 있습니다. C# 및 Python에서 사용할 수 있는 솔루션이 있지만 Go에서의 구현은 덜 간단합니다.
Go-ole을 사용한 솔루션
조사 결과 go-ole 라이브러리는 시스템 자격 증명으로 NTLM 인증을 수행하는 데 사용할 수 있는 WinHTTPRequest 인터페이스에 대한 액세스를 제공합니다. 이를 달성하는 방법은 다음과 같습니다.
<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>
이 코드는 ole 라이브러리를 초기화하고 WinHTTPRequest 인스턴스를 생성합니다. 시스템 자격 증명을 사용할 수 있도록 SetAutoLogonPolicy 메서드가 호출됩니다. 그런 다음 Open 및 Send 메서드를 사용하여 요청이 전송됩니다. 마지막으로 ResponseText 속성을 사용하여 응답 텍스트를 얻습니다.
결론
go-ole 라이브러리를 사용하면 WinHTTPRequest 인터페이스를 활용하여 시스템으로 NTLM 인증을 수행할 수 있습니다. Go의 자격 증명을 사용하여 Windows 환경에서 HTTP 요청에 대한 원활한 접근 방식을 제공합니다.
위 내용은 Go HTTP 요청에서 시스템 자격 증명으로 NTLM 인증을 달성하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!