Flurl具有执行OAuth和基本身份验证的方法:
await url.WithBasicAuth("username", "password").GetJsonAsync();
await url.WithOAuthBearerToken("mytoken").GetJsonAsync();
但是如何使用当前登录的用户执行Windows身份验证?构建在Flurl之上的HttpClientHandler具有UseDefaultCredentials属性,但我不知道如何在Flurl中使用它。
var httpClient = new HttpClient(new HttpClientHandler()
{
UseDefaultCredentials = true
});
答案 0 :(得分:7)
Flurl为每个域智能地重用HttpClientHandler,因此您不想在每次运行时都设置UseDefaultCredentials。相反,您可以修改HttpClientFactory以返回配置为UseDefaultCredentials的一个。
public class UseDefaultCredentialsClientFactory : DefaultHttpClientFactory
{
public override HttpMessageHandler CreateMessageHandler()
{
return new HttpClientHandler { UseDefaultCredentials = true };
}
}
然后,您需要告诉Flurl将要用于Windows身份验证的域使用此工厂。
public static class FlurlConfiguration
{
public static void ConfigureDomainForDefaultCredentials(string url)
{
FlurlHttp.ConfigureClient(url, cli =>
cli.Settings.HttpClientFactory = new UseDefaultCredentialsClientFactory());
}
}
然后,您只需要在启动时为每个域调用一次即可。对于ASP.NET,全局应用程序类中的Application_Start方法是一个不错的选择。
FlurlConfiguration.ConfigureDomainForDefaultCredentials("https://example.com");
FlurlConfiguration.ConfigureDomainForDefaultCredentials("http://services.example.com");
答案 1 :(得分:-1)
如果仍然有意义。您可以设置凭据,诸如此类
((HttpClientHandler)url.Client.HttpMessageHandler).Credentials = new NetworkCredential(userName, password);