假设我更新了HttpClient
并向受保护的端点发送请求,如下所示:
var httpClient = new HttpClient();
var request = new HttpRequestMessage(HttpMethod.Get, "url");
var response = await httpClient.SendAsync(request);
然后,我得到一个具有以下标题的响应:
HTTP/1.1 401 Unauthorized
Content-Type: text/html
WWW-Authenticate: Negotiate
WWW-Authenticate: NTLM
WWW-Authenticate: Basic
Date ...
从响应头中,我看到我有三个不同的选项可以与服务器进行身份验证(协商、NTLM、Basic)。然后,我将代码更新为:
var httpClientHandler = new HttpClientHandler
{
Credentials = new NetworkCredential
{
UserName = "username",
Password = "password"
}
};
var httpClient = new HttpClient(httpClientHandler);
var request = new HttpRequestMessage(HttpMethod.Get, "url");
var response = await httpClient.SendAsync(request);
我再次执行我的程序,这一次我得到200 OK作为回报。都很好。
如果我使用fiddler检查请求,我会发现HttpClient
决定使用“协商”作为身份验证方法。
现在,我的问题是:如何决定应用哪种身份验证类型?某些身份验证类型是否优先于其他身份验证类型?
NetworkCredential
上的文档声明:
NetworkCredential类是一个基类,它在基于密码的身份验证方案中提供凭据,例如basic、文摘、NTLM和Kerberos。
..。因此,我知道我提供的凭据可以应用于所有三种身份验证类型,但我无法弄清楚它是如何/为什么选择特定身份验证类型的。
任何对此的洞察力都是非常感谢的,谢谢!
发布于 2019-05-17 08:16:06
可以使用GetCredential方法,它将为您提供具有身份验证类型的凭据。有点奇怪,但很有效:
var httpClientHandler = new HttpClientHandler
{
Credentials = new NetworkCredential
{
UserName = "username",
Password = "password"
}.GetCredential("*", 80, "Basic") // Substitute * and 80 with url and port if possible
};
var httpClient = new HttpClient(httpClientHandler);
var request = new HttpRequestMessage(HttpMethod.Get, "url");
var response = await httpClient.SendAsync(request);
评论后澄清
当您有多个身份验证类型时,客户端必须使用可用的最强方法(但有时这是不确定的)。
资料来源: HTTP Authentication - WWW-Authenticate header - multiple realms
https://stackoverflow.com/questions/56182076
复制相似问题