.net使用httpclient获取http状态码_.NET Core HttpClient使用

f698de482f6a585af1535fb907d55a44.gif

前言

自从HttpClient诞生依赖,它的使用方式一直备受争议,framework版本时代产生过相当多经典的错误使用案例,包括Tcp链接耗尽、DNS更改无感知等问题。

有兴趣的同学自行查找研究。在.NET Core版本中,提供了IHttpClientFactory用来创建HttpClient以解决之前的种种问题。那么我们一起看一下它的用法。

使用方式

  • 基本用法。直接注入IHttpClientFactory

  • 命名客户端。注入IHttpClientFactory并带有名称,适用于需要特定的客户端配置

  • 类型化客户端。类似于命名客户端,但不需要名称作为标识,直接和某个服务类绑定在一起。注:这种方式经测试貌似不适用控制台程序。

  • 生成客户端。这种方式相当于在客户端生成对应的代理服务,一般特定的需要才需要这种方式。需要结合第三方库如 Refit 使用。这里不具体介绍。

示例代码

public void ConfigureServices(IServiceCollection services)
{
//普通注入
serviceCollection.AddHttpClient();
//命名注入
serviceCollection.AddHttpClient(Constants.SERVICE_USERACCOUNT, (serviceProvider, c) =>
{
var configuration = serviceProvider.GetRequiredService();
c.BaseAddress = new Uri(configuration.GetValue<string>("ServiceApiBaseAddress:UserAccountService"));
});//类型化客户端
services.AddHttpClient();
}public class AccreditationService
{private IHttpClientFactory _httpClientFactory;private const string _officialAccreName = "manage/CommitAgencyOfficialOrder";private const string _abandonAccUserName = "info/AbandonUserAccreditationInfo";public AccreditationService(IHttpClientFactory clientFactory)
{
_httpClientFactory = clientFactory;
}public async Task<string> CommitAgentOfficial(CommitAgencyOfficialOrderRequest request)
{//使用factory 创建httpclientvar httpClient = _httpClientFactory.CreateClient(Constants.SERVICE_ACCREDITATION);var response = await httpClient.PostAsJsonAsync(_officialAccreName, request);if (!response.IsSuccessStatusCode) return string.Empty;var result = await response.Content.ReadAsAsync>();if (result.ReturnCode != "0") return string.Empty;return result.Data.OrderNo;
}
}

命名化客户端方式直接注入的是HttpClient而非HttpClientFactory

public class TypedClientService
{
private HttpClient _httpClient;
public TypedClientService(HttpClient httpClient)
{
_httpClient = httpClient;
}
}

Logging

通过IHttpClientFactory创建的客户端默认记录所有请求的日志消息,并每个客户端的日志类别会包含客户端名称,例如,名为 MyNamedClient 的客户端记录类别为“System.Net.Http.HttpClient.MyNamedClient.LogicalHandler”的消息。

请求管道

同framework时代的HttpClient一样支持管道处理。需要自定义一个派生自DelegatingHandler的类,并实现SendAsync方法。例如下面的例子

public class ValidateHeaderHandler : DelegatingHandler
{
protected override async TaskSendAsync(
HttpRequestMessage request,
CancellationToken cancellationToken)
{if (!request.Headers.Contains("X-API-KEY"))
{return new HttpResponseMessage(HttpStatusCode.BadRequest)
{
Content = new StringContent("You must supply an API key header called X-API-KEY")
};
}return await base.SendAsync(request, cancellationToken);
}
}

在AddHttpClient的时候注入进去

public void ConfigureServices(IServiceCollection services)
{
services.AddTransient();
services.AddHttpClient("externalservice", c =>
{// Assume this is an "external" service which requires an API KEY
c.BaseAddress = new Uri("https://localhost:5001/");
})
.AddHttpMessageHandler();
}

原理和生存周期

IHttpClientFactory每次调用CreateHttpClient都会返回一个全新的HttpClient实例。而负责http请求处理的核心HttpMessageHandler将会有工厂管理在一个池中,可以重复使用,以减少资源消耗。HttpMessageHandler默认生成期为两分钟。可以在每个命名客户端上重写默认值:

public void ConfigureServices(IServiceCollection services)
{
services.AddHttpClient("extendedhandlerlifetime")
.SetHandlerLifetime(TimeSpan.FromMinutes(5));
}

29cd8d07f73853c8c6a83e478b9f3ca8.png

Polly支持

Polly是一款为.NET提供恢复能力和瞬态故障处理的库,它的各种策略应用(重试、断路器、超时、回退等)。IHttpClientFactory增加了对其的支持,它的nuget包为:Microsoft.Extensions.Http.Polly。

注入方式如下:

public void ConfigureServices(IServiceCollection services)
{
services.AddHttpClient()
.AddTransientHttpErrorPolicy(p =>
p.WaitAndRetryAsync(3, _ => TimeSpan.FromMilliseconds(600)));
}

更详细的结合使用请参考:https://github.com/App-vNext/Polly/wiki/Polly-and-HttpClientFactory

往期 精彩 回顾

【推荐】.NET Core开发实战视频课程 ★★★

.NET Core实战项目之CMS 第一章 入门篇-开篇及总体规划

【.NET Core微服务实战-统一身份认证】开篇及目录索引

Redis基本使用及百亿数据量中的使用技巧分享(附视频地址及观看指南)

.NET Core中的一个接口多种实现的依赖注入与动态选择看这篇就够了

10个小技巧助您写出高性能的ASP.NET Core代码

用abp vNext快速开发Quartz.NET定时任务管理界面

在ASP.NET Core中创建基于Quartz.NET托管服务轻松实现作业调度

现身说法:实际业务出发分析百亿数据量下的多表查询优化

关于C#异步编程你应该了解的几点建议

C#异步编程看这篇就够了

给我好看

e6b2bc365105232e81ad93cd36ec4a99.png

您看此文用

 3b29ccbd05e9e7fbdcad92b649a52325.gif 20f4a644f74e78dbec777fef39be7419.gif·ab7ecc1eff76315a2643cce129b62492.gif fc4edb8ccdebc36c008fee661848cf99.gif

秒,转发只需1秒呦~

b8f46dd54d4f5faaeeb3e2787d40bfbf.png

好看你就

点点

83d81dfe8be96c15f848f0b64207a422.png
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值