版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
...wd......wd......wd...Postman使用详解前言:Postman是一款功能强大的网页调试与发送网页请求的Chrome插件。接口请求流程一、get请求GET请求:点击Params,输入参数及value,可输入多个,即时显示在URL链接上,所以,GET请求的请求头与请求参数如在接口文档中无特别声明时,可以不填。get请求例如GET响应:右上角显示响应状态码、请求的耗时。get响应例如需特别注意的是注意区别状态码与响应正文中的状态码,只有状态码是200时,才代表这个接口请求是正确的,这个是协议定义的,而响应正文的状态码,是程序员自已定义的,可以是200,也可以定义为其它值,是为了让接口使用者去区分正常数据与异常数据。状态码与响应码不一致二、POST请求1、POST请求一:表单提交先看以以下图POST表单提交例如:表单提交例如上图例如中设置了请求方法,请求URL,请求参数,但没有设置请求头。有一个要明确的点是,请求头中的Content-Type与请求参数的格式之间是有关联关系的。Content-Type与请求参数的格式之间的关联中选择x-www-form-urlencoded的参数方式后,postman自动的帮我们设置了Content-Type,所以不需要我们人工干预,这就是使用一款流行工具的好处,把一些根基点都帮我们处理了。2、POST请求二:json提交先看以以下图json提交例如:json提交例如上图中,当我们选择了JSON(application/json)时,postman同样帮我们自动设置了Content-Type,可以自行的去查看Headers.3、post请求三:xml提交先看以以下图XML提交例如:XML提交例如上图中,当我们选择了XML(text/xml)时,postman同样帮我们自动设置了Content-Type,可以自行的去查看Headers.4、post请求四:自行设置Content-Type的POST请求的参数,都是放在请求正文中的,只是根据Content-Type来判断请求正文的格式,那么我们同样可以在表单提交时,选择raw,然后自行设置Content-Type为application/x-www-form-urlencoded。POST请求的参数自行设置Content-Type5、POST请求五:二进制文件提交先看以以下图二进制文件例如:二进制文件提交Body下,选择binary,在这里你可以发送视频、音频、文本等文件。三、postman断言一个完整的接口测试,包括:请求->获取响应正文->断言,我们已经知道了请求与获取响应正文,下面来介绍如何用postman进展断言。Tests这个〞Tests〞就是我们需要处理断言的地方,postman很人性化的帮我们把断言所用的函数全给准备好了:SNIPPETS举例说明:首先设置一个断言场景,根据断言场景来举例说明Postman断言如何使用。1、判断返回状态码为2002、判断响应正文中是否包含:"statusCode":2003、解析响应正文,并判断statusCode的值是200,message的值是〞Success〞第一步:在SNIPPETS中,往下拉,有一项〞Statuscode:Codeis200〞,这个就是为场景中的第1条准备的,判断返回状态码是否为200。点击这一项,可以看到在其左边,断言代码自动添加,见以以下图:Statuscode解释一下这句代码的意思:tests["Statuscodeis200"]中的tests是一个内置对象,tests["Statuscodeis200"]是指为这个断言起个名称叫〞Statuscodeis200〞,这个名称可以自行修改。responseCode.code===200中的responseCode是内置对象,responseCode对象中有个属性是code,是指状态码的code,判断code是否为200.综合起来,这句代码的意思是:名称为〞Statuscodeis200〞的断言中,判断responseCode对象的code属性值〔状态码〕是否为200。第二步:同样在SNIPPETS中,找到一项〞Responsebody:Containsstring〞,这个就是为场景中的第2条准备的,判断响应正文中的字段。点击后,在其左边,断言代码自动添加,见以以下图:Containsstring1其中我们需要修改想要在响应报文中找到的内容:tests["Bodymatchesstring"]=responseBody.has('"statusCode":200');
//对照第2条场景:判断响应正文中是否包含:"statusCode":200Containsstring2第三步:我们需要解析JSON串了,所以,在SNIPPETS中找到〞Responsebody:JSONvaluecheck〞并点击,在其左边,断言代码自动添加,见以以下图:JSONvaluecheck1我们可以看出,这里面其实是JS代码,jsonData变量其实是解析完JSON后的对象,在JS中,一个JSON对象获取其属性的值,直接是用jsonData.value,于是,我们把代码给修改一下,来判断第3条场景:tests["responsestatusCode"]=jsonData.statusCode===200;
//判断statusCode的值是200tests["responsemessage"]=jsonData.message==='Success';
//判断message的值是〞Success〞JSONvaluecheck2这样一来,我们可以看到一共有Tests的断言4个,点击Send,发送请求,在响应区内可以看到如以以下图:表示断言全部通过。以上,SNIPPETS中还有很多的函数提供给我们,努力学习吧~~~四、管理用例---CollectionsCollections集合:也就是将多个接口请求可以放在一起,并管理起来。什么样的接口请求可以放在同一个collection里在这里告诉大家可以这样:一个工程一个Collection,这样方便查找及统一处理数据。第一步:创立Collections点击上图中的带+号的图标,输入Name:〞demo〞,Description:〞demoforCollections〞,点击Create按钮即创立成功一个Collections.CreateCollections第二步,在Collections里添加请求在右侧准备好接口请求的所有数据,并验证后,点击save按钮。save按钮选择Collection及填写好Requestname、Requestdescription后,点击右下角的savetocollection按钮,那么该请求被添加到Collection中。saverequest添加成功后,可在左侧列表中,collection中查看刚刚添加的请求。第三步:Collection精细化---Folder随着放入Collection的请求越来越多,混乱就又出现了,在找一个请求时,要找半天,于是将collection中的请求分门类别就很重要了,于是,在collection中就可以添加Folder了,将一样场景的请求放入同一个Folder中,于是就实现了模块化的管理了。点击以以下图中的AddFolder后,即可创立Folder。AddFolder按钮位置添加上Foldername,即模块名称后,点击Create,创立成功一个Folder。addFolder接下来,只需要把一样场景的请求拖入一样的Folder即可,这样就实现了模块化的管理了。模块化以后的构造:模块化的管理构造第四步:运行Collection将工程模块化的用例管理起来后,借着这个管理起来的东风,也可以将工程模块化的用例执行起来,即一次执行一整个collection里的用例,或者执行一个collection里的某一个Folder里的用例。点击以以下图中的Run:run以以下图中的〞Choosecollectionorfolder〞,如果选择demo,表示运行demo这一整个collection的用例,如果选择GET,即只运行demo下的GET模块下的用例。Environment,即运行环境,是开发环境还是测试环境,需事先配置,大家可以下去自已尝试一下。Iterations,即重复运行次数。会将选择好的collection中folder重复运行。Delay,间隔时间。用例与用例间的间隔时间。Data,外部数据加载,即用例的参数化,可以与Iterations结合起来用,实现参数化,也就是数据驱动。RunDemo,点击运行,运行完成后,即可得出一个简易的聚合报告。第五步:Collection运行参数化在Iterations重复运行时,如果某个用例希望每次运行时,使用不同的数据,那么应该满足如下2个条件:1、脚本中要用到数据的地方参数化,即用一个变量来代替,每次运行时,重新获取当前的运行数据。2、需要有一个数据池,这个数据池里的数据条数,要与重复运行的次数一样。Postman的runner给我们提供了Iterations的输入项,也提供了Data的文件选择项,也就是意味着数据池是一个外部文件。如果Iterations里的值为2,那么,这个外部文件里也应该有两条数据,postman希望我们这个外部文件里的数据是一个json〔当然也可以是其它数据格式〕.为了表示两条数据,这个json应该是一个list构造(如以以下图),同时,由于脚本要用到数据的地方需要参数化,需要变量,所以,每一条数据应该就是一个map,map的key对应脚本中的变量。外部文件里的数据上图中表示提供了一个msg的变量,每次运行对应不同的值,预示着在脚本中可以用到msg这个变量,那在脚本中如何用使用变量如上图断言中用data.msg,其中data是个内置对象,即代表每一次运行的那个map数据,所以,可以用data.msg来获取每次运行的对应的值,当然,由于是个map,也可以用data[‘msg’]来获取对应的值。五、设置环境变量有时需要在不同的环境下跑一样的测试,此时可以通过设置环境变量来动态选择。点击右上角的设置按钮-ManageEnvironments:ManageEnvironments填写该环境的名称:如测试环境,并在key和value中填写需要的键值。add1add2使用这些键值的时候只需要加上两个花括号引用key,例如:{{url_base}}/admin/offer/引用key建设多个环境时,key通常都是一样的,只是value不同。创立好所有环境后,在跑用例的时候在右上角下拉列表选择需要的环境就可以了。选择环境变量六、身份验证Authentication显示browsercookies,需要开启Interceptor。点击右上角的Interceptor进展安装,并开启:Interceptor身份验证Authentication:postman有一个helpers可以帮助我们简化一些重复和复杂的任务。当前的一套helpers可以帮助你解决一些authenticationprotocols的问题。1、BasicAuth填写用户名和密码,点击updaterequest后,headers中自动添加Authorization。图中用户名和密码均使用的key变量:BasicAuth2、DigestAuth要比BasicAuth复
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 小学四年级下班主任工作计划范文
- 教师教学工作计划范文五篇
- 三年级上学期语文教学计划合集5篇
- 心理工作计划
- 2022年高中德育工作计划
- 高中数学教学工作计划模板汇编五篇
- 2022高考满分作文写酒
- 银行主任竞聘演讲稿三篇
- 下学期工作计划
- 2022国庆节创意活动方案流程策划
- 机械设计Ⅰ学习通超星期末考试答案章节答案2024年
- 英语演讲技巧与实训学习通超星期末考试答案章节答案2024年
- 智慧水产养殖解决方案10.9
- 《预防未成年人犯罪》课件(图文)
- 2024-2030年全球及中国环境健康与安全(EHS)行业市场现状供需分析及市场深度研究发展前景及规划可行性分析研究报告
- 2024年浙江省能源集团应届生招聘高频难、易错点500题模拟试题附带答案详解
- 材料工程管理人员个人年终工作总结范文
- 黑龙江金融服务支持中俄贸易的现状、不足和展望
- 福建省公路水运工程试验检测费用参考指标
- (小学组)全国版图知识竞赛考试题含答案
- 四种“类碰撞”典型模型研究(讲义)(解析版)-2025年高考物理一轮复习(新教材新高考)
评论
0/150
提交评论