当前位置: 首页 > news >正文

.Net HttpClient 使用请求数据

HttpClient 使用请求数据

0、初始化及全局设置

//初始化:必须先执行一次
#!import ./ini.ipynb

1、使用url 传参

参数放在Url里,形如:http://www.baidu.com?name=zhangsan&age=18, GET、Head请求用的比较多。优点是简单、方便,能被浏览器缓存;缺点是参数长度等限制较多,数据暴露url中,可能比较长。

/**URL传参:适合简单数据类型
*/
{//获取响应字符串{var response = await SharedClient.GetAsync("api/Normal/GetAccount?id=1");response.EnsureSuccessStatusCode();var content = await response.Content.ReadAsStringAsync();Console.WriteLine(content);}//获取响应对象{var response = await SharedClient.GetAsync("api/Normal/GetAccount?id=1");response.EnsureSuccessStatusCode();var result = await response.Content.ReadFromJsonAsync<BaseResult<Account>>();result.Display();}//直接获取响应对象{var result = await SharedClient.GetFromJsonAsync<BaseResult<Account>>("api/Normal/GetAccount?id=1");result.Display();}}

2、使用路由传参

路由参数,指参数使为URL的一部分,一般由后端API设定好,前端按规定使用即可。例如:后端指定/user/:id,前端使用/user/1,此时id为路由参数。

/*
** 路由参数:参数是URL的一部分,由后端指定
*/
{//大括号:方便折叠、开成单独的作用域var response = await SharedClient.GetAsync("api/Normal/GetAccount/管理员01");//确定是成功的响应response.EnsureSuccessStatusCode();//获取响应内容var content = await response.Content.ReadAsStringAsync();//输出 Console.WriteLine(content);
}

3、使用请求头

把请求数据放入请求头中,传给后端。当然也可以传多个数据。不过,请求头中传数据限制比较多,一般只传简单的数据:比如jwt token 。

/*
* 请求头: 值必须是字符串,如果有中文等需进行编码
*/
{//设置请求头//中文先编码,服务端接收后要解码var codedName = System.Net.WebUtility.UrlEncode("管理员01");//SharedClient是共用的,所以不能多次添加,先移除旧值if (SharedClient.DefaultRequestHeaders.Contains("name")){SharedClient.DefaultRequestHeaders.Remove("name");}//添加请求头SharedClient.DefaultRequestHeaders.Add("name", codedName);var response = await SharedClient.GetAsync("api/Normal/GetAccountFromHeader");//确定是成功的响应response.EnsureSuccessStatusCode();//获取响应内容var content = await response.Content.ReadAsStringAsync();//输出 Console.WriteLine(content);
}

4、使用请求体

把数据放在请求体中,发送到服务端。可以是简单的字符串,也可以是二进制数据(上传文件)、form表单项、编码过的form表单项、json、流式数据等形式,甚至是这个类型的组合。

说下个人的几点理解:
1、不管哪种请求体数据,都是放在请求体中,以二进制形式通过网络发往服务器,由服务器接收使用。客户端发送请求数据需要与服务端接收相配合;
2、客户端通过Content-Typey请求头设置,告诉服务端请求发送的是哪种类型的数据;服务端根据Content-Type来识别、解析请求数据。常见的类型有:multipart/form-data、application/x-www-form-urlencoded、application/json、text/plain等;
3、ASP.NET Core中,默认的请求体类型是FormUrlEncodedContent,所以默认情况下,客户端发送的请求数据是form表单项; asp.net 框架对json格式数据和表单数据进行了特殊处理,支持参数绑定等,可以使用[FromBody]特性,将请求数据绑定到对应的模型上。但普通的文本类型等不支持绑定等功能,需要从请求体中获取原始数据,自行处理。
4、一次可发送多种格式数据,由统一的分隔符分隔。服务端可以从请求头[] Content-Type: multipart/mixed; boundary=“d2e38916-df08-4fec-a40e-3e5179736f32”]拿到分隔符,然后根据分隔符将数据拆分出来。

HttpClient 中,请求体也分为这几种(常见的)类型:

  1. MultipartFormDataContent
  2. FormUrlEncodedContent
  3. JsonContent
  4. StringContent
  5. ByteArrayContent
  6. StreamContent
  7. MultipartContent

MultipartFormDataContent :Form表单

Form表单,提交数据方式之一。

/*
*   Form表单,提交数据。一般为Put或Post提交。
*/
{// 创建一个 MultipartFormDataContent 对象, 用来存入 Form表单 各项及值var formContent = new MultipartFormDataContent();// 添加表单字段formContent.Add(new StringContent("1"), "id");formContent.Add(new StringContent("管理员01"), "name");// 发送POST请求var response = await SharedClient.PostAsync("api/AdvancedGet/PostFormData", formContent);// 读取响应内容string responseString = await response.Content.ReadAsStringAsync();Console.WriteLine(responseString);
}

FormUrlEncodedContent :Form表单 asp.net core 默认接收方式

/*FormUrlEncoded 提交数据 
*/
{//设置数据项var urlEncodedData = new List<KeyValuePair<string,string>>(){new KeyValuePair<string,string>(key:"id",value:"1"),new KeyValuePair<string,string>(key:"name",value:"管理员01"),};//FormUrlEncodedContent对象var formContent = new FormUrlEncodedContent(urlEncodedData);// 发送POST请求var response = await SharedClient.PostAsync("api/AdvancedGet/PostFormData", formContent);// 读取响应内容string responseString = await response.Content.ReadAsStringAsync();Console.WriteLine(responseString);
}

StringContent 普通文本(也包括很多格式,甚至是自定义格式。要和服务器配合)

/*普通文本方式提交数据
*/
{var requestContent = new StringContent("我是请求体第一段内容", Encoding.UTF8, "text/plain");var response = await SharedClient.PostAsync("/api/AdvancedPost/TextData", requestContent);var content = await response.Content.ReadAsStringAsync();Console.WriteLine(content);
}

相关文章:

  • Python并发编程:开启性能优化的大门(7/10)
  • Redis从基础到高阶应用:核心命令解析与延迟队列、事务消息实战设计
  • 【JavaWeb+后端常用部件】
  • LeetCode面试题 01.03 URL化
  • [Java][Leetcode middle] 80. 删除有序数组中的重复项 II
  • 【Linux网络】HTTP
  • 嵌入式硬件篇---无线通信模块
  • 游戏引擎学习第272天:显式移动转换
  • 【软件工程】基于机器学习的多缺陷定位
  • 【Linux系列】bash_profile 与 zshrc 的编辑与加载
  • 一周内学完计算机网络课程之二:计算机网络物理层的理解
  • Linux电源管理(9)_wakelocks
  • 【计算机视觉】OpenCV实战项目 :Image_Cartooning_Web_App:基于深度学习的图像卡通化
  • 【Linux 系统调试】系统级追踪与性能分析利器----LTTng
  • Java反序列化漏洞
  • python:trimesh 用于 STL 文件解析和 3D 操作
  • 《用MATLAB玩转游戏开发》Flappy Bird:小鸟飞行大战MATLAB趣味实现
  • 【Leetcode 每日一题】1550. 存在连续三个奇数的数组
  • android-ndk开发(12): 获取ndk内置clang的版本详情
  • spark-Schema 定义字段强类型和弱类型
  • 日本广岛大学一处拆迁工地发现疑似未爆弹
  • 真人秀《幸存者》百万美元奖金,25年间“缩水”近一半
  • 王毅人民日报撰文:共商发展振兴,共建中拉命运共同体
  • 2025年上海好护士揭晓,上海护士五年增近两成达12.31万人
  • 为证明我爸是我爸,我将奶奶告上法庭
  • 体坛联播|巴萨4比3打服皇马,利物浦2比2战平阿森纳