Postman入门:传参方式

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

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

  • 3
    点赞
  • 16
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
1、PostMan接口参数化操作步骤; 2、环境变量设置步骤; 3、A接口返回值例如token赋值给B接口请求参数操作步骤; 图文并茂 1 接口参数化 第一步:点击右上角图标,打开环境配置页面,选择Globals,设置全局变量; 第二步:添加变量名称,设置对应的变量值,保存; 第三步:接口地址或者需要取值的参数value设置;注意需要取值的设置为{{变量名}},双大括号,即可取全局变量设置的值。 TIPS: 如果需要批量修改接口参数等,可导出后编辑,批量替换,再导入即可,注意需要修改接口地址以及下方的参数取值。 2 接口返回值存入环境变量 第一步:查看接口返回值; { "data": { "leaguerId": "161", "token": "eyJhbGciOiJIUzUxMiJ9.eyJzdWIiOiIxNjEiLCJjcmVhdGVkIjoxNTI5NTcyNTkzMTI5LCJleHAiOjE1Mjk1Nzk3OTN9.U6qmR-Qa9sJpwxShLOC8WLPBlhLxWWiQTv5bZtyOV0mdyCSHnFBb_p6T5PBY20m_0m2AmrQZGfrv6hvHCPAaow" }, "status": 200 } 第二步:在接口的TESTS页签中输入以下内容(视返回值情况修改): pm.test("Status code is 200", function () { pm.response.to.have.status(200); }); // 把responseBody转为json字符串 var Jsondata = JSON.parse(responseBody); // 设置环境变量access-token,供后面的接口引用 pm.environment.set("access-token ", Jsondata.data.token ); 第三步:重新发送上一个接口的参数信息测试,执行后查看环境变量;如图,则表示环境变量的值已经正常存储; 3 参数化取其他接口的返回值 第一步:修改需要引用上述token值的接口参数取值,参数值value设置为{{access-token}}({{变量名}}),测试接口,正确返回即可;

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值