.Net?HttpClient?使用請求數(shù)據(jù)的處理方法
HttpClient 使用請求數(shù)據(jù)
0、初始化及全局設(shè)置
//初始化:必須先執(zhí)行一次 #!import ./ini.ipynb
1、使用url 傳參
參數(shù)放在Url里,形如:http://www.baidu.com?name=zhangsan&age=18, GET、Head請求用的比較多。優(yōu)點是簡單、方便,能被瀏覽器緩存;缺點是參數(shù)長度等限制較多,數(shù)據(jù)暴露url中,可能比較長。
/**
URL傳參:適合簡單數(shù)據(jù)類型
*/
{
//獲取響應(yīng)字符串
{
var response = await SharedClient.GetAsync("api/Normal/GetAccount?id=1");
response.EnsureSuccessStatusCode();
var content = await response.Content.ReadAsStringAsync();
Console.WriteLine(content);
}
//獲取響應(yīng)對象
{
var response = await SharedClient.GetAsync("api/Normal/GetAccount?id=1");
response.EnsureSuccessStatusCode();
var result = await response.Content.ReadFromJsonAsync<BaseResult<Account>>();
result.Display();
}
//直接獲取響應(yīng)對象
{
var result = await SharedClient.GetFromJsonAsync<BaseResult<Account>>("api/Normal/GetAccount?id=1");
result.Display();
}
}2、使用路由傳參
路由參數(shù),指參數(shù)使為URL的一部分,一般由后端API設(shè)定好,前端按規(guī)定使用即可。例如:后端指定/user/:id,前端使用/user/1,此時id為路由參數(shù)。
/*
** 路由參數(shù):參數(shù)是URL的一部分,由后端指定
*/
{//大括號:方便折疊、開成單獨的作用域
var response = await SharedClient.GetAsync("api/Normal/GetAccount/管理員01");
//確定是成功的響應(yīng)
response.EnsureSuccessStatusCode();
//獲取響應(yīng)內(nèi)容
var content = await response.Content.ReadAsStringAsync();
//輸出
Console.WriteLine(content);
}3、使用請求頭
把請求數(shù)據(jù)放入請求頭中,傳給后端。當然也可以傳多個數(shù)據(jù)。不過,請求頭中傳數(shù)據(jù)限制比較多,一般只傳簡單的數(shù)據(jù):比如jwt token 。
/*
* 請求頭: 值必須是字符串,如果有中文等需進行編碼
*/
{
//設(shè)置請求頭
//中文先編碼,服務(wù)端接收后要解碼
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");
//確定是成功的響應(yīng)
response.EnsureSuccessStatusCode();
//獲取響應(yīng)內(nèi)容
var content = await response.Content.ReadAsStringAsync();
//輸出
Console.WriteLine(content);
}4、使用請求體
把數(shù)據(jù)放在請求體中,發(fā)送到服務(wù)端??梢允呛唵蔚淖址部梢允嵌M制數(shù)據(jù)(上傳文件)、form表單項、編碼過的form表單項、json、流式數(shù)據(jù)等形式,甚至是這個類型的組合。
說下個人的幾點理解:
1、不管哪種請求體數(shù)據(jù),都是放在請求體中,以二進制形式通過網(wǎng)絡(luò)發(fā)往服務(wù)器,由服務(wù)器接收使用。客戶端發(fā)送請求數(shù)據(jù)需要與服務(wù)端接收相配合;
2、客戶端通過Content-Typey請求頭設(shè)置,告訴服務(wù)端請求發(fā)送的是哪種類型的數(shù)據(jù);服務(wù)端根據(jù)Content-Type來識別、解析請求數(shù)據(jù)。常見的類型有:multipart/form-data、application/x-www-form-urlencoded、application/json、text/plain等;
3、ASP.NET Core中,默認的請求體類型是FormUrlEncodedContent,所以默認情況下,客戶端發(fā)送的請求數(shù)據(jù)是form表單項; asp.net 框架對json格式數(shù)據(jù)和表單數(shù)據(jù)進行了特殊處理,支持參數(shù)綁定等,可以使用[FromBody]特性,將請求數(shù)據(jù)綁定到對應(yīng)的模型上。但普通的文本類型等不支持綁定等功能,需要從請求體中獲取原始數(shù)據(jù),自行處理。
4、一次可發(fā)送多種格式數(shù)據(jù),由統(tǒng)一的分隔符分隔。服務(wù)端可以從請求頭[] Content-Type: multipart/mixed; boundary=“d2e38916-df08-4fec-a40e-3e5179736f32”]拿到分隔符,然后根據(jù)分隔符將數(shù)據(jù)拆分出來。
HttpClient 中,請求體也分為這幾種(常見的)類型:
- MultipartFormDataContent
- FormUrlEncodedContent
- JsonContent
- StringContent
- ByteArrayContent
- StreamContent
- MultipartContent
MultipartFormDataContent :Form表單
Form表單,提交數(shù)據(jù)方式之一。
/*
* Form表單,提交數(shù)據(jù)。一般為Put或Post提交。
*/
{
// 創(chuàng)建一個 MultipartFormDataContent 對象, 用來存入 Form表單 各項及值
var formContent = new MultipartFormDataContent();
// 添加表單字段
formContent.Add(new StringContent("1"), "id");
formContent.Add(new StringContent("管理員01"), "name");
// 發(fā)送POST請求
var response = await SharedClient.PostAsync("api/AdvancedGet/PostFormData", formContent);
// 讀取響應(yīng)內(nèi)容
string responseString = await response.Content.ReadAsStringAsync();
Console.WriteLine(responseString);
}FormUrlEncodedContent :Form表單 asp.net core 默認接收方式
/*
FormUrlEncoded 提交數(shù)據(jù)
*/
{
//設(shè)置數(shù)據(jù)項
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);
// 發(fā)送POST請求
var response = await SharedClient.PostAsync("api/AdvancedGet/PostFormData", formContent);
// 讀取響應(yīng)內(nèi)容
string responseString = await response.Content.ReadAsStringAsync();
Console.WriteLine(responseString);
}StringContent 普通文本(也包括很多格式,甚至是自定義格式。要和服務(wù)器配合)
/*
普通文本方式提交數(shù)據(jù)
*/
{
var requestContent = new StringContent("我是請求體第一段內(nèi)容", Encoding.UTF8, "text/plain");
var response = await SharedClient.PostAsync("/api/AdvancedPost/TextData", requestContent);
var content = await response.Content.ReadAsStringAsync();
Console.WriteLine(content);
}到此這篇關(guān)于.Net HttpClient 使用請求數(shù)據(jù)的文章就介紹到這了,更多相關(guān).Net HttpClient請求數(shù)據(jù)內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
.NET客戶端實現(xiàn)Redis中的管道(PipeLine)與事物(Transactions)
本文主要介紹了.NET客戶端實現(xiàn)Redis中的管道(PipeLine)與事物(Transactions)的相關(guān)知識。具有很好的參考價值,下面跟著小編一起來看下吧2017-03-03
net core webapi多版本控制與swagger(nswag)配置教程
這篇文章主要介紹了net core webapi多版本控制與swagger(nswag)配置,本文給大家介紹的非常詳細,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2020-11-11
vs2012創(chuàng)建的ado.net模型無法實例化的解決方案
本文給大家分享的是升級vs2012后,發(fā)現(xiàn)創(chuàng)建數(shù)據(jù)模型無法實例化使用,嘗試了很多種方法,最后在度娘的幫助下,才解決了這個問題,這里記錄下來,分享給大家。2015-03-03
.Net?Core?使用?TagProvider?與?Enricher?豐富日志的操作代碼
這篇文章主要介紹了.Net?Core?使用?TagProvider?與?Enricher?豐富日志的操作,本文通過示例代碼給大家介紹的非常詳細,需要的朋友可以參考下2024-03-03
創(chuàng)建一個完整的ASP.NET Web API項目
ASP.NET Web API具有與ASP.NET MVC類似的編程方式,ASP.NET Web API不僅僅具有一個完全獨立的消息處理管道,而且這個管道比為ASP.NET MVC設(shè)計的管道更為復(fù)雜,功能也更為強大。下面創(chuàng)建一個簡單的Web API項目,需要的朋友可以參考下2015-10-10

