システム資格情報を使用した 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 中国語 Web サイトの他の関連記事を参照してください。