C#.NET HttpClient 使用教程

简介

HttpClient.NET 中用于发送 HTTP 请求和接收 HTTP 响应的现代化 API,它取代了过时的 WebClientHttpWebRequest 类。

HttpClient.NET Framework 4.5 + 和 .NET Core/.NET 5+ 中提供的、基于消息处理管道(message handler pipeline)的现代 HTTP 客户端库。

相比早期的 HttpWebRequest,它更易用、支持异步、可扩展性强,并且在 .NET Core 中底层使用 SocketsHttpHandler,性能与可配置性都有显著提升。

底层架构

  • HttpClient

    • 封装请求创建、发送及响应处理逻辑,提供 GetAsync、PostAsync、SendAsync 等方法。
  • HttpMessageHandler 管道

    • 默认使用 SocketsHttpHandler(.NET Core/.NET 5+).NET Framework 下为 HttpClientHandler

    • 可以通过继承 DelegatingHandler 串联多个自定义中间件(例如日志、重试、认证)。

  • 连接池与长连接

    • SocketsHttpHandler 内置连接池和 HTTP/2 支持,同一目标主机复用 TCP 连接,减少握手与重建成本。

HttpClient 核心特性

特性说明优势
异步支持所有方法都有异步版本避免阻塞线程,提高并发能力
连接池自动管理 HTTP 连接减少 TCP 连接开销
超时控制可配置请求超时时间防止长时间阻塞
内容处理内置多种内容处理器简化 JSON/XML 处理
取消支持支持 CancellationToken优雅终止长时间请求
扩展性可通过 DelegatingHandler 扩展实现日志、重试等中间件

常用方法

使用单例
public static class HttpClientSingleton
{public static readonly HttpClient Instance = new HttpClient();
}// 使用
await HttpClientSingleton.Instance.GetAsync(url);
  • 全局唯一,避免重复创建 handler,复用连接池。

  • 需注意:设置到期(Timeout)、默认头(DefaultRequestHeaders)等全局属性变更会影响所有调用。

使用 HttpClientFactory 工厂
services.AddHttpClient("GitHub", client =>
{client.BaseAddress = new Uri("https://api.github.com/");client.DefaultRequestHeaders.Add("User-Agent", "MyApp");
})
.AddTransientHttpErrorPolicy(policy =>policy.WaitAndRetryAsync(3, _ => TimeSpan.FromSeconds(2)));// 使用
var client = _httpClientFactory.CreateClient("GitHub");
  • 框架管理生命周期、稳定重用 SocketsHttpHandler

  • 支持命名客户端、类型化客户端、配置管道、添加 Polly 弹性策略。

类型化客户端
public class GitHubService {private readonly HttpClient _client;public GitHubService(HttpClient client) => _client = client;// 封装API方法
}
// 注册
services.AddHttpClient<GitHubService>(client => { /* 配置 */ });
GET 请求
var client = HttpClientSingleton.Instance;
var response = await client.GetAsync("https://api.example.com/items/1");
response.EnsureSuccessStatusCode();
string json = await response.Content.ReadAsStringAsync();
POST 请求
var content = new StringContent(JsonSerializer.Serialize(new { Name = "测试" }),Encoding.UTF8, "application/json");
var postResp = await client.PostAsync("https://api.example.com/items", content);
postResp.EnsureSuccessStatusCode();
SendAsync 自定义请求
var request = new HttpRequestMessage(HttpMethod.Put, $"items/{id}")
{Content = new StringContent(json, Encoding.UTF8, "application/json")
};
request.Headers.Add("X-Custom", "Value");using var resp = await client.SendAsync(request, HttpCompletionOption.ResponseHeadersRead);
resp.EnsureSuccessStatusCode();
流式上传/下载
// 下载
using var resp = await client.GetAsync(fileUrl, HttpCompletionOption.ResponseHeadersRead);
using var stream = await resp.Content.ReadAsStreamAsync();
// 将 stream 写入文件 ...// 上传
using var fs = File.OpenRead(localFilePath);
var streamContent = new StreamContent(fs);
var uploadResp = await client.PostAsync(uploadUrl, streamContent);
DelegatingHandler 管道
public class LoggingHandler : DelegatingHandler
{protected override async Task<HttpResponseMessage> SendAsync(HttpRequestMessage request, CancellationToken ct){Console.WriteLine($"Request: {request}");var resp = await base.SendAsync(request, ct);Console.WriteLine($"Response: {resp}");return resp;}
}// 注册(HttpClientFactory)
services.AddHttpClient("WithLogging").AddHttpMessageHandler<LoggingHandler>();
Polly 弹性策略
services.AddHttpClient("GitHub").AddTransientHttpErrorPolicy(p =>p.WaitAndRetryAsync(3, retry => TimeSpan.FromSeconds(1)));
  • AddTransientHttpErrorPolicy 捕获 5xx、408、HttpRequestExceptiontransient 错误;

  • 可组合断路器、超时、隔离策略。

认证与配置
  • Bearer Token
client.DefaultRequestHeaders.Authorization =new AuthenticationHeaderValue("Bearer", accessToken);
  • Client Certificates
var handler = new HttpClientHandler();
handler.ClientCertificates.Add(new X509Certificate2("cert.pfx", "pwd"));
var client = new HttpClient(handler);
  • 代理
handler.Proxy = new WebProxy("http://127.0.0.1:8888");
handler.UseProxy = true;
设置超时和请求头
httpClient.Timeout = TimeSpan.FromSeconds(30); // 设置全局超时
httpClient.DefaultRequestHeaders.Add("User-Agent", "MyApp/1.0");
httpClient.DefaultRequestHeaders.Authorization = new AuthenticationHeaderValue("Bearer", "your-token");
处理不同类型的响应
// 获取 JSON 响应
var jsonResponse = await httpClient.GetStringAsync("https://api.example.com/json");// 获取二进制响应(如文件下载)
var bytes = await httpClient.GetByteArrayAsync("https://example.com/file.pdf");// 获取流响应(大文件下载,避免内存溢出)
await using var stream = await httpClient.GetStreamAsync("https://example.com/largefile.zip");await using var fileStream = File.Create("largefile.zip");
await stream.CopyToAsync(fileStream);
发送带参数的请求
// GET 请求带查询参数
var queryParams = new Dictionary<string, string>
{{ "page", "1" },{ "size", "20" }
};
var uri = new UriBuilder("https://api.example.com/data")
{Query = new FormUrlEncodedContent(queryParams).ReadAsStringAsync().Result
};
var response = await httpClient.GetAsync(uri.Uri);// POST 请求带表单数据
var formContent = new FormUrlEncodedContent(new[]
{new KeyValuePair<string, string>("username", "test"),new KeyValuePair<string, string>("password", "pass")
});
await httpClient.PostAsync("https://example.com/login", formContent);
处理 HTTP 错误
try
{var response = await httpClient.GetAsync("https://api.example.com/resource");response.EnsureSuccessStatusCode(); // 非 200 状态码会抛出异常
}
catch (HttpRequestException ex)
{Console.WriteLine($"HTTP Error: {ex.StatusCode}");Console.WriteLine($"Message: {ex.Message}");
}
处理 gzip/deflate 压缩响应
var httpClientHandler = new HttpClientHandler
{AutomaticDecompression = DecompressionMethods.GZip | DecompressionMethods.Deflate
};
var httpClient = new HttpClient(httpClientHandler);
取消操作
var cts = new CancellationTokenSource(TimeSpan.FromSeconds(10)); // 10秒超时
try {var response = await client.GetAsync("https://slow-api.com", cts.Token);
} catch (TaskCanceledException) {// 处理超时
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如若转载,请注明出处:http://www.pswp.cn/diannao/88702.shtml
繁体地址,请注明出处:http://hk.pswp.cn/diannao/88702.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Nginx常用安全配置指南

Nginx是一个轻量级的&#xff0c;高性能的Web服务器以及反向代理和邮箱代理服务器。它运行在UNIX、GNU、linux、BSD、Mac OS X、Solaris和Windows各种版本。根据调查统计数据显示&#xff0c;当前全球超过6%的网站使用Nginx Web服务器来管理Web网站应用。 为了保证基于Nginx的…

【UniApp 日期选择器实现与样式优化实践】

UniApp 日期选择器实现与样式优化实践 发布时间&#xff1a;2025/6/26 前言 在移动端应用开发中&#xff0c;日期选择器是一个常见且重要的交互组件。本文将分享我们在 UniApp 项目中实现自定义日期选择器的经验&#xff0c;特别是在样式优化过程中遇到的问题及解决方案。通过…

推荐系统的视频特征-视频关键帧特征提取与向量生成

&#x1f4cc; 总体流程概览 视频文件 (.mp4)↓ 关键帧抽取&#xff08;FFmpeg / SceneDetect&#xff09;↓ 帧图像&#xff08;.jpg&#xff09;↓ 图像模型提取特征&#xff08;CLIP / CNN / ViT&#xff09;↓ 多帧聚合成视频向量&#xff08;均值池化等&#xff09;↓ 向…

Apache SeaTunnel Flink引擎执行流程源码分析

目录 1. 任务启动入口 2. 任务执行命令类:FlinkTaskExecuteCommand 3. FlinkExecution的创建与初始化 3.1 核心组件初始化 3.2 关键对象说明 4. 任务执行:FlinkExecution.execute() 5. Source处理流程 5.1 插件初始化 5.2 数据流生成 6. Transform处理流程 6.1 插…

Vue 3 + Element Plus 实现「动态表单组件」详解教程

✅ Vue 3 Element Plus 实现「动态表单组件」详解教程 &#x1f4cc; 适用场景&#xff1a;表单字段根据配置动态生成&#xff0c;支持校验、提交、自定义组件、复杂布局等。 &#x1f9e9; 技术栈&#xff1a;Vue 3 TypeScript Element Plus &#x1f527; 核心特性&#x…

本地部署开源时间跟踪工具 Kimai 并实现外部访问( Windows 版本)

Kimai 是一款开源的时间跟踪工具&#xff0c;它易于使用&#xff0c;并提供了强大的报告功能&#xff0c;在个人和团队记录工作时间、项目时间和活动时间等之后可以帮助用户了解他们是如何花费时间的&#xff0c;从而提高生产力和效率。本文将详细介绍如何在 Windows 系统本地部…

系统分析师案例知识点

目录 1 必做题1.1 状态机图1.2 活动图1.3 统一软件开发过程RUP 2 需求分析2.1 数据流图DFD2.2 ER图2.3 状态转换图STD2.4 数据字典2.5 流程图2.6 需求评审2.7 设计类2.8 FAST分析2.9 常见的关系类 3 嵌入式3.1 容器技术3.2 虚拟机技术3.3 虚拟机和容器的不同点 4 数据库4.1 NoS…

多相机人脸扫描设备如何助力高效打造数字教育孪生体?

在教育数字化转型浪潮中&#xff0c;数字孪生体作为现实教育场景的虚拟映射&#xff0c;正成为智慧教育发展的关键技术支点。传统教育模式面临师资资源分布不均、个性化教学难以覆盖、跨时空教学场景受限等痛点&#xff0c;而数字孪生体通过构建高仿真虚拟教育主体&#xff08;…

用 EXCEL/WPS 实现聚类分析:赋能智能客服场景的最佳实践

聚类分析作为无监督学习的核心技术&#xff0c;能在客服数据中发现隐藏的用户群体或问题模式。尽管 Excel/WPS 并非专业统计软件&#xff0c;但巧妙利用其内置功能&#xff0c;也能实现基础的聚类分析&#xff0c;为中小型客服团队提供快速洞察。以下介绍具体方法及智能客服场景…

基于定制开发开源AI智能名片S2B2C商城小程序源码的H5游戏开发模式创新研究

摘要 本文以定制开发开源AI智能名片S2B2C商城小程序源码为技术底座&#xff0c;探讨其在H5游戏开发中的创新应用。通过分析原生开发与第三方工具两种传统开发模式的局限性&#xff0c;提出将AI智能名片的多模态内容生成能力、S2B2C商城的生态协同机制与H5游戏开发深度融合的解…

vue3+ELInput无法输入的问题

vue3ElInput无法输入的问题 开篇 写业务的时候发现&#xff0c;因为想偷懒嘛&#xff0c;直接就在想在外部去定义一个变量&#xff0c;然后写个弹窗里&#xff08;tsx&#xff09;的el-input&#xff0c;而不是又去写个vue页面&#xff0c;但发现就输入不了了&#xff0c;而且…

SQL Server:如何检测和修复 FILESTREAM 数据库损坏?

SQL Server 中的 FILESTREAM 功能可以将二进制大型对象 &#xff08;BLOB&#xff09; 存储到文件系统上&#xff0c;而不是将它们存储在数据库中。但是&#xff0c;默认情况下不启用此功能。用户需要使用 SQL Server Management Studio &#xff08;SSMS&#xff09; 和 SQL S…

FORCE 开发者论坛 | 火山引擎发布多款 Agent 开发工具

资料来源&#xff1a;火山引擎-开发者社区 6 月 12 日&#xff0c;2025 火山引擎 FORCE 原动力大会开发者论坛成功举办。大会聚焦 Agent 开发新范式&#xff0c;升级发布了 PromptPilot、MCP Servers、TRAE、扣子开发平台等产品&#xff0c;以及多款开源项目&#xff0c;构建起…

【Qt-windows】如何使用perfmon 具体分析windows serverR2的Qt程序CPU问题

可以使用 Windows 自带的 PerfMon&#xff08;Performance Monitor&#xff09; 工具对运行在 Windows Server R2 上的 Qt 程序进行详细的性能分析&#xff0c;尤其是 CPU 使用情况。以下是具体的操作步骤和建议&#xff1a; 一、打开 PerfMon 工具 按下 Win R 打开运行窗口。…

【软考高级系统架构论文】论NoSQL数据库技术及其应用

论文真题 随着互联网web2.0网站的兴起,传统关系数据库在应对web2.0 网站,特别是超大规模和高并发的web2.0纯动态 SNS 网站上已经显得力不从心,暴露了很多难以克服的问题,而非关系型的数据库则由于其本身的特点得到了非常迅速的发展。 NoSQL(Not only SQL )的产生就是为了解…

bash的配置文件,source

一.按生效范围分类 二.按shell登录的方式分类 这里的执行顺序存疑,因为会互相调用,不需要记忆 source执行脚本 source不创建子进程,bash创建子进程 普通脚本:用bash 配置文件脚本:用source 三.按功能分类

30道C语言高频题整理(附答案背诵版)

1.请描述一下C语言的基本数据类型有哪些&#xff1f; C语言提供了一系列的基本数据类型&#xff0c;它们是构建更复杂数据结构的基础。这些基本数据类型主要包括&#xff1a; 整型&#xff08;Integer Types&#xff09;&#xff1a;用于存储整数值。根据存储大小和符号性&…

使用Tailwind CSS和i18n的react实践

首先在 src 下设置 i18n.js 文件 // src/i18n.js import i18n from i18next; import { initReactI18next } from react-i18next;import en from ./locales/en/public; import zh from ./locales/zh/public;i18n.use(initReactI18next) .init({resources: {en: { translation:…

生信自学路线|R语言的数据变量类型与对应运算

R 是一种动态类型语言&#xff0c;使用灵活&#xff0c;变量无需预先声明类型。掌握 R 的数据类型和变量机制&#xff0c;是后续进行数据处理和建模分析的基础。本章节主要介绍 R 语言中的常量、变量、基本数据类型及常用数据结构&#xff0c;并结合示例进行说明。 文章目录 一…

UI前端大数据处理优化策略:提升数据处理速度与准确性

hello宝子们...我们是艾斯视觉擅长ui设计、前端开发、数字孪生、大数据、三维建模、三维动画10年经验!希望我的分享能帮助到您!如需帮助可以评论关注私信我们一起探讨!致敬感谢感恩! 在数字化浪潮下&#xff0c;前端面临的数据规模正呈指数级增长 ——IDC 预测&#xff0c;2025…