시스템 자격 증명을 사용한 Go HTTP 요청의 NTLM 인증
이 질문에서 사용자는 Go HTTP에서 Windows NTML 인증을 수행하는 방법에 대한 지침을 구합니다. 호출 사용자의 시스템 자격 증명을 사용하여 요청합니다. 해당 언어에서 이를 달성하는 방법을 보여주는 C# 및 Python의 예제를 제공합니다.
해결책은 Go에서 WinHTTPRequest를 사용할 수 있게 해주는 go-ole 라이브러리를 활용하는 것입니다. Python 예제와 유사한 접근 방식을 따르면 Go에서 시스템 자격 증명을 사용하여 NTML 인증을 구현할 수 있습니다.
이를 수행하는 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())
}
이 코드는 WinHTTPRequest 개체를 초기화하고, 현재 사용자의 자격 증명을 사용하도록 자동 로그온 정책을 설정하고, 지정된 URL에 대한 GET 요청을 열고, 요청을 보내고, 응답 텍스트를 검색합니다.
부인 성명: 제공된 모든 리소스는 부분적으로 인터넷에서 가져온 것입니다. 귀하의 저작권이나 기타 권리 및 이익이 침해된 경우 자세한 이유를 설명하고 저작권 또는 권리 및 이익에 대한 증거를 제공한 후 이메일([email protected])로 보내주십시오. 최대한 빨리 처리해 드리겠습니다.
Copyright© 2022 湘ICP备2022001581号-3