前言
当下编写应用程序都流行前后端分离,后端提供对应服务接口给前端或跨应用程序调用,如WebAPI等。在调用这些服务接口发送HTTP请求,而.NET为我们提供了HttpWebRequest、HttpClient几个类库来实现。下面对C#使用HttpClient类发送HTTP请求数据的几种格式。
HttpClient
HttpClient是.NET 4.5以上版提供的类(System.Net.Http),编写的应用程序可以通过此类发送HTTP请求并从WEB服务公开的资源接收HTTP响应。HTTP请求包含了请求报文与响应报文。下面先简单的了解它的一些属性与方法。| 属性 | 描述 |
|---|
| BaseAddress | 获取或设置发送请求时地址。 |
| DefaultProxy | 获取或设置全局HTTP请求代理。 |
| DefaultRequestHeaders | 获取请求发送的标题。 |
| DefaultRequestVersion | 获取或设置请求使用的默认HTTP版本。 |
| MaxResponseContentBufferSize | 获取或设置读取响应内容时要缓冲的最大字节数。 |
| Timeout | 获取或设置请求超时等待的时间。 |
| 方法 | 描述 |
|---|
| GetAsync | 异步请求获取指定URI。 |
| GetByteArrayAsync | 异步请求获取指定URI并以字节数组的形式返回响应。 |
| GetStreamAsync | 异步请求获取指定URI并以流的形式返回响应。 |
| GetStringAsync | 异步请求获取指定URI并以字符串的形式返回响应正文。 |
| PostAsync | 异步将POST请求发送给指定URI。 |
| Send | 发送带有指定请求的 HTTP 请求。 |
| SendAsync | 以异步操作发送 HTTP 请求。 |
数据格式
在向HTTP发起请求时,将以什么样的数据格式发送数据,这取决于URI服务资源。而常用的类型可分为application/json、application/x-www-form-urlencoded, multipart/form-data, text/xml,其中application/json 是近年来最常用的一种。下面简单介绍每种格式。
JSON数据格式
application/json 通常是HttpClient发送JSON格式的数据,通过使用HttpContent的StringContent并设置其MediaType为"application/json"。using Newtonsoft.Json;using System;using System.Net.Http;using System.Net.Http.Headers;using System.Text;using System.Threading.Tasks;
namespace Fountain.WinConsole.HttpDemo{ internal class Program { static async Task Main(string[] args) { try { using (HttpClient httpClient = new HttpClient()) { User user = new User(); user.username = "test"; user.password = "123456"; string jsonData = JsonConvert.SerializeObject(user); // 发送请求数据包 StringContent content = new StringContent(jsonData, Encoding.UTF8); // 设置HTTP 响应上的ContentType --application/json content.Headers.ContentType = new MediaTypeHeaderValue("application/json"); // 请求访问地址 string url = "https://127.0.0.1/api/user/login"; // 发出HTTP的Post请求 HttpResponseMessage response = await httpClient.PostAsync(url, content); // 读取返回结果 string responseContent = await response.Content.ReadAsStringAsync(); // 将字符转对象 Result result = JsonConvert.DeserializeObject<Result>(responseContent); } } catch (Exception exception) { Console.WriteLine(exception.Message); } Console.ReadLine(); } }}
表单数据格式
application/x-www-form-urlencoded 这种格式通常用于表单数据的提交,通过使用HttpContent的FormUrlEncodedContent 类定义实现。using Newtonsoft.Json;using Newtonsoft.Json.Linq;using System;using System.Collections;using System.Collections.Generic;using System.Net.Http;using System.Net.Http.Headers;using System.Text;using System.Threading.Tasks;
namespace Fountain.WinConsole.HttpDemo{ internal class Program { static async Task Main(string[] args) { try { using (HttpClient httpClient = new HttpClient()) { Dictionary<string,string> user = new Dictionary<string, string> { { "username", "test" }, { "password", "123456" } }; // 发送请求数据包 FormUrlEncodedContent content = new FormUrlEncodedContent(user); // 请求访问地址 string url = "https://127.0.0.1/api/user/login"; // 发出HTTP的Post请求 HttpResponseMessage response = await httpClient.PostAsync(url, content); // 读取返回结果 string responseContent = await response.Content.ReadAsStringAsync(); // 将字符转对象 Result result = JsonConvert.DeserializeObject<Result>(responseContent); } } catch (Exception exception) { Console.WriteLine(exception.Message); } Console.ReadLine(); } }}
文件上传格式
multipart/form-data 常用于文件上传的数据格式,通过用MultipartFormDataContent类定义实现。using Newtonsoft.Json;using Newtonsoft.Json.Linq;using System;using System.Collections;using System.Collections.Generic;using System.IO;using System.Net.Http;using System.Net.Http.Headers;using System.Text;using System.Threading.Tasks;
namespace Fountain.WinConsole.HttpDemo{ internal class Program { static async Task Main(string[] args) { try { using (HttpClient httpClient = new HttpClient()) { MultipartFormDataContent multipartContent = new MultipartFormDataContent(); multipartContent.Add(new StringContent("user"), "test"); multipartContent.Add(new ByteArrayContent(File.ReadAllBytes(string.Format("{0}{1}", AppDomain.CurrentDomain.BaseDirectory, "test.jpg"))), "image", "test.jpg"); // 请求访问地址 string url = "https://127.0.0.1/api/user/upload"; // 发出HTTP的Post请求 HttpResponseMessage response = await httpClient.PostAsync(url, multipartContent); // 读取返回结果 string responseContent = await response.Content.ReadAsStringAsync(); // 将字符转对象 Result result = JsonConvert.DeserializeObject<Result>(responseContent); } } catch (Exception exception) { Console.WriteLine(exception.Message); } Console.ReadLine(); } }}
XML数据格式
text/xml 主要用于传输XML格式的数据,通过使用HttpContent 中的StringContent并设置其MediaType为"text/xml"。using Newtonsoft.Json;using Newtonsoft.Json.Linq;using System;using System.Collections;using System.Collections.Generic;using System.IO;using System.Net.Http;using System.Net.Http.Headers;using System.Text;using System.Threading.Tasks;
namespace Fountain.WinConsole.HttpDemo{ internal class Program { static async Task Main(string[] args) { try { using (HttpClient httpClient = new HttpClient()) { StringBuilder user = new StringBuilder(); user.AppendLine("<usrname>test</usrname>"); user.AppendLine("<password>test123456</password>"); string xmlData = user.ToString(); // 发送请求数据包 StringContent content = new StringContent(xmlData, Encoding.UTF8); // 设置HTTP 响应上的ContentType --text/xml content.Headers.ContentType = new MediaTypeHeaderValue("text/xml"); // 请求访问地址 string url = "https://127.0.0.1/api/user/login"; // 发出HTTP的Post请求 HttpResponseMessage response = await httpClient.PostAsync(url, content); // 读取返回结果 string responseContent = await response.Content.ReadAsStringAsync(); // 将字符转对象 Result result = JsonConvert.DeserializeObject<Result>(responseContent); } } catch (Exception exception) { Console.WriteLine(exception.Message); } Console.ReadLine(); } }}
小结
以上是C#在使用HttpClient类发起 HTTP 的Post请求时,使用四种数据格式的方式。希望对各位有所帮助。如有不到之处,请多多包涵。
该文章在 2024/6/8 18:15:51 编辑过