我有一个与 Windows 服务对话的 Web 应用程序(托管在 IIS 中)。 Windows 服务使用 ASP.Net MVC Web API(自托管),因此可以使用 JSON 通过 http 进行通信。 Web 应用程序配置为进行模拟,其想法是向 Web 应用程序发出请求的用户应该是 Web 应用程序用来向服务发出请求的用户。结构如下所示:
(以红色突出显示的用户是以下示例中提到的用户。)
Web 应用程序使用 HttpClient
向 Windows 服务发出请求:
var httpClient = new HttpClient(new HttpClientHandler()
{
UseDefaultCredentials = true
});
httpClient.GetStringAsync("http://localhost/some/endpoint/");
这向 Windows 服务发出请求,但没有正确传递凭据(该服务将用户报告为 IIS APPPOOL\ASP.NET 4.0
)。 这不是我想要发生的事情。
如果我将上面的代码更改为使用 WebClient
相反,用户的凭据被正确传递:
WebClient c = new WebClient
{
UseDefaultCredentials = true
};
c.DownloadStringAsync(new Uri("http://localhost/some/endpoint/"));
使用上述代码,服务将用户报告为向 Web 应用程序发出请求的用户。
我在 HttpClient
实现上做错了什么导致它无法正确传递凭据(或者它是 HttpClient的错误
)?
我想使用 HttpClient
的原因是它有一个与 Task
配合良好的异步 API,而 WebClient
的 asyc API 需要用事件来处理。
最佳答案
您可以将 HttpClient
配置为自动传递凭证,如下所示:
var myClient = new HttpClient(new HttpClientHandler() { UseDefaultCredentials = true });
关于c# - 如何让 HttpClient 随请求一起传递凭据?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/12212116/