Postman入门:传参方式

本文深入探讨了HTTP请求中的multipart/form-data格式,解释了它是如何处理表单数据和文件上传的,包括其与post方法的区别,请求头和请求体的构造方式。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

1.form-data

就是http请求中的multipart/form-data,它会将表单的数据处理为一条消息,以标签为单元,用分隔符分开。既可以上传键值对,也可以上传文件,一次可以传多个。其中Multipart/form-data其实就是上传文件的一种方式。http协议本身的原始方法其实并不支持multipart/form-data请求,它是由post方法来组合实现的,multipart/form-data与post方法的不同之处——请求头,请求体:

multipart/form-data的请求头必须包含一个特殊的头信息:Content-Type,且其值也必须规定为multipart/form-data,同时还需要规定一个内容分割符用于分割请求体中的多个post的内容,如文件内容和文本内容自然需要分割开来,不然接收方就无法正常解析和还原这个文件了。

multipart/form-data的请求体也是一个字符串,不过和post的请求体不同的是它的构造方式,post是简单的name=value值连接,而multipart/form-data则是添加了分隔符等内容的构造体,格式如下:

----------------------------565792946877230312524239
Content-Disposition: form-data; name=""; filename="name"

LiLei
----------------------------565792946877230312524239

其中第一行是自定义的分割符,需要与请求头中规定的分割符相同。

其实根据前言中的例子,可以很容易看出,这个请求体是多个类似的部分组成的:每一个部分都是以分隔符开始的,然后是该部分内容的描述信息,然后一个回车,然后是描述信息的具体内容;如果传送的内容是一个文件的话,那么还会包含文件名信息,以及文件内容的类型。最后会以分割符结尾,表示请求体结束。具体如下所示:

Header = {"Content-type" : "multipart/form-data, boundary=------WebKitFormBoundaryA0Srut8TBztAofvx"}  

Data =  '''
------WebKitFormBoundaryA0Srut8TBztAofvx
Content-Disposition: form-data; name="client_id"

a3cef7c66a1843f8b3a9e6b1e5162e21
------WebKitFormBoundaryA0Srut8TBztAofvx
Content-Disposition: form-data; name="grant_type"

password
------WebKitFormBoundaryA0Srut8TBztAofvx
Content-Disposition: form-data; name="timestamp"

1520246977964
------WebKitFormBoundaryA0Srut8TBztAofvx
Content-Disposition: form-data; name="source"

com.zhihu.web
------WebKitFormBoundaryA0Srut8TBztAofvx
Content-Disposition: form-data; name="utm_source"


------WebKitFormBoundaryA0Srut8TBztAofvx--

2.x-www-form-urlencoded

上传的是键值对,一次可以上传多个,并使用&分开,如

3.raw

上传任意格式的文本,可以上传text、json、xml、html等。

4.binary

上传二进制数据,通常用来上传文件,由于没有键值,所以,一次只能上传一个文件。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值