Bri*_*ian 2 c# authentication http x509certificate2 flurl
我正在与Flurl一起使用需要基于证书的身份验证的API。我从这篇SO帖子中看到,向中添加证书WebRequestHandler并指示an 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);
Run Code Online (Sandbox Code Playgroud)
无法编译,因为HttpClient无法转换为FlurlClient
使用ConfigureHttpClient
var clientFactory = new DefaultHttpClientFactory();
FlurlClient fc = new Url("foobar.com").ConfigureHttpClient(client => client = clientFactory
.CreateClient(url, handler));
Run Code Online (Sandbox Code Playgroud)
这似乎是最可行的选择,但是我不确定,因为委托是Action没有返回类型的。
问题
使用Flurl支持客户端证书认证的最佳/正确方法是什么?
您已经接近了-定制工厂肯定是您要走的路。但是您想覆盖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;
}
}
Run Code Online (Sandbox Code Playgroud)
然后,您可以在全球范围内注册它(在应用启动时):
FlurlHttp.Configure(settings => {
settings.HttpClientFactory = new X509HttpFactory(myCert);
});
Run Code Online (Sandbox Code Playgroud)
或针对特定主机的所有呼叫:
FlurlHttp.ConfigureClient(ROOT_URL, cli => {
cli.Settings.HttpClientFactory = new X509HttpFactory(myCert);
});
Run Code Online (Sandbox Code Playgroud)
或换一个新的FlurlClient:
var cli = new FlurlClient(url)
.Configure(settings => settings.HttpClientFactory = new X509HttpFactory(myCert));
Run Code Online (Sandbox Code Playgroud)
或现有的一个:
cli.Settings.HttpClientFactory = new X509HttpFactory(myCert);
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
1493 次 |
| 最近记录: |