【问题标题】:Sending HTTP Headers with HTTP Web Request for NTLM Authentication使用 HTTP Web 请求发送 HTTP 标头以进行 NTLM 身份验证
【发布时间】:2010-12-03 23:46:33
【问题描述】:

我想登录一个 Sharepoint 门户,该门户会显示一个登录对话框,但使用的是 NTLM 身份验证。如何修改 C# 中的 HTTP 标头以发出成功的登录请求?我假设我需要向门户登录部分中的页面发出 HTTPWebRequest 并在此旁边发布 HTTP 标头集合?

【问题讨论】:

    标签: c# asp.net sharepoint ntlm


    【解决方案1】:

    为了对 WebRequest 使用 NTLM 身份验证,凭据信息应存储在 CredentialCache

    var request = (HttpWebRequest)WebRequest.Create(url);
    // INIT REQUEST HERE ...
    
    var credential = new NetworkCredential(username, password, domain);
    var credentialCache = new CredentialCache();
    credentialCache.Add(new Uri(url), "NTLM", credential);
    request.Credentials = credentialCache;
    
    // SEND ...
    

    来源:http://predicatet.blogspot.com/2007/01/httpwebrequest-networkcredential-with.html

    【讨论】:

      【解决方案2】:

      要使用 NTLM,请参阅John's 答案。如果您需要跨会话的标头,请查看 HttpWebRequest 对象上的 CookieContainer 属性。您需要保留对 CookieContainer 的引用,并将其附加到您创建的任何其他 HttpWebRequest。

      【讨论】:

        【解决方案3】:

        您可以使用 WebRequest 类来做到这一点。

        WebRequest req = WebRequest.Create(tokenUri);
        req.AuthenticationLevel = System.Net.Security.AuthenticationLevel.MutualAuthRequested;
        req.Credentials = System.Net.CredentialCache.DefaultNetworkCredentials;
        WebResponse resp = req.GetResponse();
        StreamReader reader = new StreamReader(resp.GetResponseStream());
        var token = reader.ReadToEnd().Trim();
        

        此代码将整个响应读入名为token 的变量中。

        【讨论】:

        • 尝试这个时我得到The remote server returned an error: (401) Unauthorized。相同的 URL/用户/密码适用于 Firefox。 HTTP 上的 NTLM
        猜你喜欢
        • 1970-01-01
        • 1970-01-01
        • 1970-01-01
        • 1970-01-01
        • 1970-01-01
        • 2011-12-05
        • 1970-01-01
        • 2023-03-10
        • 2022-06-12
        相关资源
        最近更新 更多