知识点
本文是一个很另类的文章,在项目中用的比较少,但如果项目中真的出现了这种情况,我们也需要知道如何去解决,对于知识点StringContent和FormUrlEncodedContent我们应该了解的多一点,FormUrlEncodedContent是以键/值对的形式进行POST数据的提供,同时要求服务端以x-www-form-urlencoded的方式去接收数据!而StringContent是ByteArrayContent的一个子集,也是MultipartFormDataContent的一个子集,在进行大数据传输时,我们需要使用这种方法,如果传递的是字符串,可以采用StringContent,如果是二进制流,可以使用ByteArrayContent,而这两种方式都可以对外以MultipartFormDataContent的形式体现,而在服务端要以mutipart/form-data的方式来接收数据!
再深一点
multipart/form-data: 就是http请求中的multipart/form-data,它会将表单的数据处理为一条消息,以标签为单元,用分隔符分开。既可以上传键值对,也可以上传文件。当上传的字段是文件时,会有Content-Type来表名文件类型;content-disposition,用来说明字段的一些信息;由于有boundary(分隔符号)隔离,所以multipart/form-data既可以上传文件,也可以上传键值对,它采用了键值对的方式,所以可以上传多个文件。
x-www-form-urlencoded:会将表单数据转成键/值对进行传递,有大小的限制,一般是2M。
Raw:可以上传任何格式文本,你需要显示的说明content-type,如text/plain,text/html,text/json,text/xml等。
Binary:一般上传文件流,它相当于content-type为application/octet-stream的情况。
从上面的介绍不难发现,raw和binary方式都属于multipart/form-data,只不过是两种不同的体现而以。
DotNet平台为WebAPI传递大数据
对于普通方式的HttpClient(x-www-form-urlencoded)有时已经不能满足我们的需要了,所以必须上multipart/form-data,即在HttpClient构建时,采用StringContent的内容类型,下面是在客户端构建一个HttpClient的方式,以服务端(webapi restful)传递一个大大的JSON对象!
var list = new List<TestApiModel>();entity.Category = new Category { Title = "北京" };entity.OrderList = new List<OrderList> {new OrderList{Price=1,ProductName="tel",Address=new Address {Province="印度"}},new OrderList{Price=100,ProductName="tv",Address=new Address {Province="日本"}},new OrderList{Price=999,ProductName="pc",Address=new Address {Province="美国"}}};for (int i = 0; i <= 100; i++)list.Add(entity);var handler = new HttpClientHandler(){AutomaticDecompression = System.Net.DecompressionMethods.GZip};using (var http = new HttpClient(handler)){var body = entity.ToNameValueCollection();var content = new StringContent(list.ToJson(), Encoding.UTF8, "text/json");var responseResult = http.PostAsync(UriAddress, content).Result;}
如果客户端采用了这种StringContent的方式,那么在设计WebApi时只有两种选择,第一种就是使用JSON强类型(类对象)的参数,第二种就是不写参数(空),如果使用string类型的参数,那这个接口无法被找到,即出现的结果是404的状态码!下面看一下服务端的数据处理,也是很简单!
public async Task<HttpResponseMessage> Post()//没有参数表示使用raw,form-data方式进行传输{try{var data =await Request.Content.ReadAsStringAsync();var entity = Lind.DDD.Utils.SerializeMemoryHelper.DeserializeFromJson<IEnumerable<TestApiModel>>(data);
}
//.......
}
上面代码从请求上下文中拿到了这个大数据的字符串,然后通过反序列化得到了下面的结果:
当然,对于非常友好的webapi来说,你完全可以在方法参数上显示的使用强类型,这种api框架会帮助我们进行序列化的操作,真的很友好!
这行list对象已经被架构进行了序列化操作
通过本篇文章,让我们更清楚的认识到了POST请求的几种方式,以及他们与服务端(api)如何去结合,对于java,.net平台,这些方法都是同样适用的!
来自:https://www.cnblogs.com/lori/p/5919306.html