Go HTTP 요청에서 시스템 자격 증명을 사용한 NTLM 인증
개발자로서 HTTP 요청을 수행하고 인증해야 하는 시나리오가 발생할 수 있습니다. 애플리케이션을 실행하는 사용자의 시스템 자격 증명을 사용합니다. Windows 환경에서는 NTLM(Negotiate Token Level Message) 인증을 사용하여 이를 수행할 수 있습니다. C# 및 Python에서 사용할 수 있는 솔루션이 있지만 Go에서의 구현은 덜 간단합니다.
Go-ole을 사용한 솔루션
조사 결과 go-ole 라이브러리는 시스템 자격 증명으로 NTLM 인증을 수행하는 데 사용할 수 있는 WinHTTPRequest 인터페이스에 대한 액세스를 제공합니다. 이를 달성하는 방법은 다음과 같습니다.
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())
}
이 코드는 ole 라이브러리를 초기화하고 WinHTTPRequest 인스턴스를 생성합니다. 시스템 자격 증명을 사용할 수 있도록 SetAutoLogonPolicy 메서드가 호출됩니다. 그런 다음 Open 및 Send 메서드를 사용하여 요청이 전송됩니다. 마지막으로 응답 텍스트는 ResponseText 속성을 사용하여 가져옵니다.
결론
go-ole 라이브러리를 사용하면 WinHTTPRequest 인터페이스를 활용하여 시스템에서 NTLM 인증을 수행할 수 있습니다. Go의 자격 증명을 사용하여 Windows 환경에서 HTTP 요청에 대한 원활한 접근 방식을 제공합니다.
부인 성명: 제공된 모든 리소스는 부분적으로 인터넷에서 가져온 것입니다. 귀하의 저작권이나 기타 권리 및 이익이 침해된 경우 자세한 이유를 설명하고 저작권 또는 권리 및 이익에 대한 증거를 제공한 후 이메일([email protected])로 보내주십시오. 최대한 빨리 처리해 드리겠습니다.
Copyright© 2022 湘ICP备2022001581号-3