C#Flurl – 将WebRequestHandler添加到FlurlClient

我正在与Flurl合作,以获得需要基于证书的身份validation的API。 我从这篇SOpost中看到,向WebRequestHandler添加证书并指示HttpClient使用此处理程序很容易。

但是,使用Flurl对我来说并不是那么清楚。 我尝试了以下三件事。

扩展DefaultHttpFactory

我首先怀疑我需要创建自己的X509HttpFactory : DefaultHttpFactory ,它将创建处理程序并将其分配给HttpClient 。 但是,在查看源代码时,我注意到CreateClient的构造函数已经需要一个处理程序。 这个处理程序来自哪里?

使用DefaultHttpFactory创建客户端

 WebRequestHandler handler = new WebRequestHandler(); handler.ClientCertificates.Add(myX509Cert); var clientFactory = new DefaultHttpClientFactory(); FlurlClient fc = clientFactory.CreateClient(url, handler); 

由于HttpClient无法转换为FlurlClient因此无法编译

使用ConfigureHttpClient

 var clientFactory = new DefaultHttpClientFactory(); FlurlClient fc = new Url("foobar.com").ConfigureHttpClient(client => client = clientFactory .CreateClient(url, handler)); 

这似乎是最可行的选项,但我不确定,因为委托是一个没有返回类型的Action

问题

使用Flurl支持客户端证书身份validation的最佳/正确方法是什么?

你很亲密 – 定制工厂绝对是你要走的路。 但是您想要覆盖CreateMessageHandler而不是CreateClient

 public class X509HttpFactory : DefaultHttpClientFactory { private readonly X509Certificate2 _cert; public X509HttpFactory(X509Certificate2 cert) { _cert = cert; } public override HttpMessageHandler CreateMessageHandler() { var handler = new WebRequestHandler(); handler.ClientCertificates.Add(_cert); return handler; } } 

然后你可以在全球注册它(在应用启动时):

 FlurlHttp.Configure(settings => { settings.HttpClientFactory = new X509HttpFactory(myCert); }); 

或者对特定主机的所有呼叫:

 FlurlHttp.ConfigureClient(ROOT_URL, cli => { cli.Settings.HttpClientFactory = new X509HttpFactory(myCert); }); 

或者对于新的FlurlClient

 var cli = new FlurlClient(url) .Configure(settings => settings.HttpClientFactory = new X509HttpFactory(myCert)); 

或现有的:

 cli.Settings.HttpClientFactory = new X509HttpFactory(myCert);