form-data、x-www-form-urlencoded、raw、binary的区别(非原创)
文章大纲
一、form-data介绍
二、x-www-form-urlencoded介绍
三、raw介绍
四、binary介绍
五、参考文章
一、form-data介绍
http请求中的multipart/form-data,它会将表单的数据处理为一条消息,以标签为单元,用分隔符分开。既可以上传键值对,也可以上传文件。当上传的字段是文件时,会有Content-Type来表名文件类型;content-disposition,用来说明字段的一些信息;
由于有boundary隔离,所以multipart/form-data既可以上传文件,也可以上传键值对,它采用了键值对的方式,所以可以上传多个文件。
![](https://upload-images.jianshu.io/upload_images/16598307-9a26707ba251e61f.png?imageMogr2/auto-orient/strip%7CimageView2/2/w/723/format/webp)
![](https://upload-images.jianshu.io/upload_images/16598307-ac74e8cc7beb617b.png?imageMogr2/auto-orient/strip%7CimageView2/2/w/688/format/webp)
二、x-www-form-urlencoded介绍
application/x-www-from-urlencoded,会将表单内的数据转换为键值对,比如,name=java&age = 23
![](https://upload-images.jianshu.io/upload_images/16598307-8c560e4e6d80d3d4.png?imageMogr2/auto-orient/strip%7CimageView2/2/w/658/format/webp)
![](https://upload-images.jianshu.io/upload_images/16598307-3eedfb1c62b4c92c.png?imageMogr2/auto-orient/strip%7CimageView2/2/w/507/format/webp)
三、raw介绍
可以上传任意格式的文本,可以上传text、json、xml、html等
content-type= text/html(HTML 文档);text/plain(纯文本);text/css(CSS 样式表);application/json (json字符串)
![](https://upload-images.jianshu.io/upload_images/16598307-beef49b30d28e710.png?imageMogr2/auto-orient/strip%7CimageView2/2/w/754/format/webp)
![](https://upload-images.jianshu.io/upload_images/16598307-c3d364c861fa7f64.png?imageMogr2/auto-orient/strip%7CimageView2/2/w/520/format/webp)
四、binary介绍
相当于Content-Type:application/octet-stream,从字面意思得知,只可以上传二进制数据,通常用来上传文件,由于没有键值,所以,一次只能上传一个文件。
multipart/form-data与x-www-form-urlencoded区别
multipart/form-data:既可以上传文件等二进制数据,也可以上传表单键值对,
x-www-form-urlencoded:只能上传键值对,并且键值对都是间隔分开的,只是最后会转化为一条信息。
五、参考文章
I hate being alone,but I'm afraid I won't get married early