0

0

C#怎么调用WebAPI接口_C#如何通过Postman风格发送请求【技巧】

尼克

尼克

发布时间:2026-03-19 05:53:22

|

569人浏览过

|

来源于php中文网

原创

HttpClient是.NET Core/5+官方推荐的线程安全、支持连接池的HTTP客户端,应全局单例复用;POST JSON用StringContent设application/json,表单用FormUrlEncodedContent;自定义Header需提前设置,禁用.Result避免死锁。

c#怎么调用webapi接口_c#如何通过postman风格发送请求【技巧】

HttpClient 发送 POST 请求,别再手写 HttpWebRequest

直接上 HttpClient,它是 .NET Core / .NET 5+ 官方推荐、线程安全、支持连接池的首选方式。手写 HttpWebRequest 不仅冗长,还容易漏关流、复用失败、超时不生效。

常见错误现象:HttpRequestException: Connection refused 或请求卡死 —— 很可能是没正确复用 HttpClient 实例(比如每次请求都 new 一个)。

  • 全局只创建一次 HttpClient 实例(建议注入为 Singleton)
  • PostAsync + StringContent 发 JSON,记得设 MediaType"application/json"
  • 务必 await,别忘了 EnsureSuccessStatusCode() 检查 HTTP 状态码
var client = new HttpClient();
var json = JsonSerializer.Serialize(new { name = "test" });
var content = new StringContent(json, Encoding.UTF8, "application/json");
var response = await client.PostAsync("https://api.example.com/users", content);
response.EnsureSuccessStatusCode(); // 抛出 4xx/5xx 异常

POST 表单数据(application/x-www-form-urlencoded)怎么发

不是所有 WebAPI 都接受 JSON;有些老接口只认表单键值对,比如登录接口或 ASP.NET MVC 后端。这时候不能传 JSON 字符串,得用 FormUrlEncodedContent

容易踩的坑:把对象直接序列化成 JSON 再塞进 FormUrlEncodedContent —— 这会导致后端收不到任何字段,因为格式完全不匹配。

  • Dictionary<string, string> 构建键值对
  • 传中文时不用手动 URL 编码,FormUrlEncodedContent 会自动处理
  • 如果后端要求空值字段也提交,字典里显式加 "",别跳过 key
var data = new Dictionary<string, string>
{
    { "username", "admin" },
    { "password", "123" }
};
var content = new FormUrlEncodedContent(data);
var response = await client.PostAsync("https://api.example.com/login", content);

如何模拟 Postman 的「Raw → JSON」和「Headers 手动加」

Postman 的 Raw JSON 模式本质就是带 Content-Type: application/json 的 POST;而自定义 Header(比如 Authorization: Bearer xxx)必须在 request 发出前设置,不能靠响应头反推。

如此AI员工
如此AI员工

国内首个全链路营销获客AI Agent

下载

性能影响:Header 太多或值太长不会显著拖慢,但 Authorization 值泄露(如硬编码在代码里)是严重安全风险。

  • Header 必须调用 client.DefaultRequestHeaders.Add()request.Headers.Add()
  • Bearer Token 建议从配置或密钥管理服务读取,别写死
  • 如果某个请求要临时覆盖全局 Header(比如换 token),就别用 DefaultRequestHeaders,改用 HttpRequestMessage 实例
var request = new HttpRequestMessage(HttpMethod.Post, "https://api.example.com/data");
request.Headers.Authorization = new AuthenticationHeaderValue("Bearer", "xxx-token");
request.Content = new StringContent(json, Encoding.UTF8, "application/json");
var response = await client.SendAsync(request);

同步调用(.Result)为什么总卡死或死锁

在 ASP.NET Core MVC 控制器或 WinForms/WPF UI 线程里直接调 PostAsync().Result,99% 会死锁 —— 因为 await 试图回调到被阻塞的上下文,而那个上下文正等着 .Result 返回。

兼容性影响:.NET Framework 下更敏感;.NET 6+ 默认禁用同步上下文,但 UI 框架(如 WPF)仍会恢复它。

  • 永远用 await,不要 .Result.Wait()
  • Controller Action 必须标记 async Task<IActionResult>,不能是 Task<IActionResult> 少了 async
  • 实在无法异步(如第三方库强制同步入口),用 ConfigureAwait(false) 降低风险,但只是缓解,不是解法

复杂点在于:死锁不报错,只卡住,调试时看不出异常,容易误判为网络问题或 API 故障。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

WorkBuddy
WorkBuddy

腾讯云推出的AI原生桌面智能体工作台

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
c#是什么意思
c#是什么意思

C#是一种通用的面向对象编程语言,它在.NET框架上运行,可用于开发各种类型的应用程序。本专题为大家提供c#相关的各种文章、以及下载和课程。

279

2023.08.08

什么是c#
什么是c#

C#(读作C Sharp)是一种现代的、通用的、面向对象的编程语言。它由微软公司开发,于2000年首次发布,主要用于开发Windows桌面应用程序、Web应用程序、移动应用程序以及游戏开发等领域。C#是一种类型安全和托管的编程语言,它结合了C++的强大性能和C语言的简单易学特点,并引入了许多新的特性和概念,如委托、属性、泛型和异步编程等,以提高开发效率和代码可维护性。

185

2023.08.31

C#中base关键字的用法
C#中base关键字的用法

在C#中,base关键字用于访问当前类的基类成员,这包括基类的字段、属性、方法、构造函数、索引器以及事件。想了解更多C#的相关内容,可以阅读本专题下面的文章。

327

2024.03.13

C#Task用法
C#Task用法

Task在C#中是用于表示异步操作的对象,它位于System.Threading.Tasks命名空间中。想了解更多C#中各种用法的相关内容,可以阅读本专题下面的文章。

380

2024.03.14

C# 并发与异步编程
C# 并发与异步编程

本专题系统讲解 C# 异步编程与并发控制,重点介绍 async 和 await 关键字、Task 类、线程池管理、并发数据结构、死锁与线程安全问题。通过多个实战项目,帮助学习者掌握 如何在 C# 中编写高效的异步代码,提升应用的并发性能与响应速度。

29

2026.02.03

C# 多线程与异步编程
C# 多线程与异步编程

本专题深入讲解 C# 中多线程与异步编程的核心概念与实战技巧,包括线程池管理、Task 类的使用、async/await 异步编程模式、并发控制与线程同步、死锁与竞态条件的解决方案。通过实际项目,帮助开发者掌握 如何在 C# 中构建高并发、低延迟的异步系统,提升应用性能和响应速度。

107

2026.02.06

C# ASP.NET Core微服务架构与API网关实践
C# ASP.NET Core微服务架构与API网关实践

本专题围绕 C# 在现代后端架构中的微服务实践展开,系统讲解基于 ASP.NET Core 构建可扩展服务体系的核心方法。内容涵盖服务拆分策略、RESTful API 设计、服务间通信、API 网关统一入口管理以及服务治理机制。通过真实项目案例,帮助开发者掌握构建高可用微服务系统的关键技术,提高系统的可扩展性与维护效率。

415

2026.03.11

抖漫入口地址合集
抖漫入口地址合集

本专题整合了抖漫入口地址相关合集,阅读专题下面的文章了解更多详细地址。

109

2026.03.17

多环境下的 Nginx 安装、结构与运维实战
多环境下的 Nginx 安装、结构与运维实战

本专题聚焦多环境下Nginx实战,详解开发、测试及生产环境的差异化安装策略与目录结构规划。深入剖析配置模块化设计、灰度发布流程及跨环境同步机制。结合监控告警、故障排查与自动化运维工具,提供全链路管理方案,助力团队构建灵活、高可用的Nginx服务体系,从容应对复杂业务场景挑战。

13

2026.03.17

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
C# 教程
C# 教程

共94课时 | 11.6万人学习

C 教程
C 教程

共75课时 | 5.6万人学习

C++教程
C++教程

共115课时 | 22.5万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号