| |
|
开发:
C++知识库
Java知识库
JavaScript
Python
PHP知识库
人工智能
区块链
大数据
移动开发
嵌入式
开发工具
数据结构与算法
开发测试
游戏开发
网络协议
系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程 数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁 |
-> 开发工具 -> 【2022全网最全教程】接口调试神器:Postman 从入门到进阶教程(万字长文) -> 正文阅读 |
|
[开发工具]【2022全网最全教程】接口调试神器:Postman 从入门到进阶教程(万字长文) |
postman是一款支持http协议的接口调试与测试工具,其主要特点就是功能强大,使用简单且易用性好 。 无论是开发人员进行接口调试,还是测试人员做接口测试,postman都是我们的首选工具之一 。 那么接下来就介绍下postman到底有哪些功能,它们分别都能干些什么 。下面先通过一张图来直观的来看下postman中所包含的功能 。 当然,以上功能也只是展示了postman的一部分功能,为了能更加全面的体现这款工具的特点,我将从以下三个维度来加以说明。它们分别是:
「一. postman安装说明」【文末免费分享自动化测试全套学习资源】postman 在 2018 年之后就不再支持浏览器版本,所以,想要使用它就必须先下载客户端再安装使用,下面就以 Windows 系统为例进行安装 。 「1. 下载与安装」 postman安装步骤: \1. 访问postman官方网站,下载最新版本 访问地址:https://www.getpostman.com/ \2. 进入到下载页面,根据自己电脑下载对应的版本 img \3. 双击下载的安装包,进入到安装界面,直到用户登录和注册界面。 若个人使用,选择跳过即可,这时会进入到postman主界面,至此postman安装成功(下图)。 若团队使用,可以进行注册,注册后使用账号可以加入团队工作区 img 「2.界面导航说明」 初次使用postman的朋友可能对界面上的一些元素不太熟悉,下面就通过一张图来说明这些元素的含义 。 img 「3.发送第一个请求」 如果你是第一次使用postman发送请求,下面这个例子可以作为一个最基本的入门,可以帮我们建立一个初始印象 。 \1. 打开postman,点击+加号打开一个新的请求页。 \2. 在请求的URL中输入请求地址: http://www.weather.com.cn/data/sk/101010100.html \3. 点击Send按钮,这时就可以在下部的窗格中看到来自服务器的json响应数据。 img 「二.postman基础功能」「1.常见类型的接口请求」 常见的接口有如下四种类型,分别是含有查询参数的接口,表单类型的接口,json类型的接口以及含有上传文件的接口,以下就对这四种类型接口及如何在postman中请求进行说明 。 「1.1 .查询参数的接口请求」 「什么是查询参数?」 所谓的查询参数,其实就是URL地址中问号(?)后面的部分就叫查询参数,比如:http://cx.shouji.360.cn/phonearea.php?number=13012345678 。在这个接口中,查询参数就是:「number=13012345678」?。 而这一部分是由有键值对组成,格式为:key1=value1&key2=value2, 如果有多组键值对,要用&隔开 。 「postman如何请求」 在postman中实现对这类接口请求非常简单,一般就需要明确俩个参数即可,一个是请求方法,一个请求地址。 针对上面的那个接口,地址已经给出 ,而它的请求方法是get 。那么在postman中只需要把这俩个参数填写上即可请求 。 具体实现步骤: \1. 打开postman,新建一个请求。 \2. 在请求方法中选择请求方法:GET,因为在postman中默认的请求方法就是GET,所以这一步可以忽略 \3. 接口URL中输入地址,点击Send按钮就可以发送请求了 。 img 说明:查询参数的URL一般直接拷贝到输入的URL地址栏中就可以了,当然也可以把查询参数在Params中输入,俩者的效果是一样的 。 「1.2 表单类型的接口请求」 「什么是表单 ?」 我们都知道,在发送HTTP请求的时候,一个请求中一般包含三个部分,分别是请求行,请求头,请求体 。 不同的接口,请求体的数据类型是不一样的,比较常见的一种就是表单类型,那么什么是表单类型呢 ?简单理解就是在请求头中查看「Content-Type,它的值如果是:application/x-www-form-urlencoded」?.那么就说明客户端提交的数据是以表单形式提交的 。见下图: img 「postman中如何请求?」 如果在postman请求上图的接口,我们只需要填写四个参数,分别是(可以参考上图):
实现步骤:
img 「1.3 上传文件的表单请求」 在做接口测试时,我们经常会遇到需要上传文件的接口,比如微信的更新头像。这就需要用到:multipart/form-data。它也属于一种表单,但它既支持表单请求,也支持文件上传。它的请求报文中数据往往是下面这样的。
这种类型的接口,在postman中该如何请求呢 ?我们先分析需要填写的参数 。
实现步骤:
img 「1.4 json类型的接口请求」 这应该是接口测试中最常见的一种情况了 , 也就是请求体类型为json,我们来看下这个请求报文 。
根据以上报文,我们可以分析出,我们在postman只需要填写四个参数即可,具体如下:
实现步骤:
img 「2.接口响应数据解析」 响应数据是发送请求后经过服务器处理后返回的结果,响应由三部分组成,分别是状态行、响应头、响应体。我们来看下postman的响应数据展示。 img 在postman中的响应数据展示:
那么这些数据对我们做接口测试有什么作用呢 ?
接下来我们再来关注下Body中的几个显示主题,分别是:Pretty,Raw,Preview . img Pretty:翻译成中文就是漂亮 , 也就是说返回的Body数据在这个标签中查看 ,都是经过格式化的,格式化后的数据看起来更加直观,所以postman默认展示的也是这个选项。比如返回html页面,它会经过格式化成HTML格式后展示,比如返回json,那么也会格式化成json格式展示 。 Raw:翻译成中文未经过加工的,也就是原始数据 ,原始数据一般都是本文格式的,未经过格式化处理的,一般在抓包工具中都有这个选项 。 Preview:翻译成中文就是预览,这个选项一般对返回HTML的页面效果特别明显,如请求百度后返回结果,点击这个选项后就直接能查看到的页面 ,如下图 。同时这个选项和浏览器抓包中的Preview也是一样的 。 img 「3. 接口管理(Collection)」 当我们对一个或多个系统中的很多用例进行维护时,首先想到的就是对用例进行分类管理,同时还希望对这批用例做回归测试 。在postman也提供了这样一个功能,就是Collection 。通过这个Collection就可以满足我们的上面说的需求。 先对Collection功能的使用场景做个简单总结 。
那么Collection是如何去管理用例的呢 ?先想象我们要测试一个系统,系统下有多个模块,每个模块下有很多的被测接口用例 。那么基于这个场景,我们来通过Collection来进行实现: \1. 点击Collection,点击+New Collection,在弹出的输入框中输入Collection名称(这个就可以理解为所测试的系统) img \2. 选中新建的Collection右键,点击Add Folder ,在弹出对话框中输入文件夹名称(这个就可以理解为系统中的模块) img \3. 选中新建的Folder,点击Add Request ,在弹出的对话框中输入请求名称,这个就是我们所测试的接口,也可以理解为测试用例 。 img 那么通过以上三个步骤,达到的效果就是如图所示: img 总结,通过上面的操作,我们实现了一个最简单的demo模型。但实际上,有了这个功能才是postman学习的开始,因为很多功能都是基础这个功能的基础上进行的,比如用例的批量执行,Mock ,接口文档等功能 。 「4. 批量执行接口请求」 当我们在一个Collection中编写了很多的接口测试用例,想一起执行这批用例,在postman中是如何操作呢 ? 实现步骤: \1. 选中一个Collection,点击右三角,在弹出的界面点击RUN img \2. 这是会弹出一个叫Collection Runner的界面,默认会把Collection中的所有用例选中 。 img \3. 点击界面下方的RUN Collection,就会对Collection中选中的所有测试用例运行 。 img 对上面的几个红框内的功能进行简单说明:
总体来说,这个功能主要是用于对一个Collection中的所有用例或部分用例进行批量运行,已达到手工回归测试的目的。 「5.日志调试」 在做接口测试时,经常会因为代码写的有问题导致报错,这时通过查看日志就显得非常重要了,postman也提供了这样的功能,它允许我们在脚本中编写打印语句,查看打印的结果 ; 同时也可以查看每个请求的日志信息 。 在postman中编写日志打印语句使用的是JavaScript,编写的位置可以是Pre-request Script 或Tests标签中。编写打印语句如:console.log("我是一条日志") img 那么打印的日如何看呢 ?在postman中有俩个入口,第一个入口就是:view-show postman console 。 第二个入口就是左下角第三个图标 。 img 打开的日志界面: img 这里面有几个比较实用的功能:
总之,通过这个功能,我们在请求接口报错时,通过打印响应的日志,就能很轻松的找到问题原因了 。 「6.断言」 如果没有断言,我们只能做接口的功能测试,但有了断言后,就为我们做自动化提供了条件,并且在postman中的断言是非常方便和强大的 。 我们先来了解下postman断言的一些特点 ,具体如下
在上面我们介绍到,编写的断言代码是JavaScript,那如果不会写怎么办 ?不用担心,因为postman已经给我们内置了一些常用的断言 。用的时候,只需从右侧点击其中一个断言,就会在文本框中自动生成对应断言代码块 。 img 接下来就让我们了解一些常用断言,还是按响应的组成来划分,分别是状态行,响应头,响应体。 状态行中又包括状态码,状态消息 。在postman也可以对这两个进行断言 「状态行中的断言」:
「响应头中的断言」
「断言响应体(重点)」
「响应时间(一般用于性能测试)」
「案例说明」: 针对以下接口返回的数据进行断言:
img 总结,整体来说,如果用postman做接口测试,这个断言功能必不可少,其中我们常断言的响应体包含和JSON这俩个断言又是重重之重。 「7. 变量(全局/集合/环境)」 变量可以使我们在请求或脚本中存储和重复使用其值,通过将值保存在变量中,可以在集合,环境或请求中引用。 对我们做接口测试来说,又是一个非常重要的功能 。 在postman常用的三种变量分别是全局变量,环境变量,集合变量 。
其中,他们的作用域范围依次从大到小:全局变量>集合变量>环境变量 。当在几个不同的范围内都申明了相同的变量时,则会优先使用范围最小的变量使。 想要使用变量中的值只需俩个步骤,分别是定义变量和获取变量 。
「定义变量」 定义全局变量和环境变量,点击右上角的小齿轮,弹出如下界面,就可以根据需求定义全局变量或者环境变量了。 img 已经定义的全局变量和环境变量,可以进行快速查看: img 「定义集合变量」 选择一个集合,打开查看更多动作(「...」)菜单,然后点击编辑 。选择“变量”选项卡以编辑或添加到集合变量。 img 定义变量除了以上方式,还有另外一种方式 。但是这种方式在不同的位置定义,编写不一样。 在URL,Params , Authorization , Headers , Body中定义: \1. 手工方式创建一个空的变量名 \2. 在以上的位置把想要的值选中右击,选中Set:环境|全局 ,选中一个变量名,点击后就会保存到这个变量中 img 在Tests,Pre-requests Script:
「获取变量」 定义好变量,接下来就可以使用变量了 。需要注意的是,在不同的位置获取变量,编写的规则也是不一样的 。 如果在「请求参数中」获取变量,无论是获取全局变量,还是环境变量,还是集合变量,获取的方式都是一样的编写规则:{{变量名}} 。
如果是在编写代码的位置(Tests,Pre-requests Script)获取变量,获取不同类型的变量,编写的代码都不相同,具体如下:
img 变量的使用场景非常广泛,比如我们后面要提到的接口关联,请求前置脚本都会使用到变量 。 「8. 请求前置脚本」 前置脚本其实就是在Pre-requests Script中编写的JavaScript脚本,想要了解这个功能,需要先了解它的执行顺序。那么下面就来看下它的执行顺序 。 可以看出,一个请求在发送之前,会先去执行Pre Request Script(前置脚本)中的代码 。那么这个功能在实际工作中有什么作用呢 ? 主要场景:一般情况下,在发送请求前需要对接口的数据做进一步处理,就都可以使用这个功能,比如说,登录接口的密码,在发送前需要做加密处理,那么就可以在前置脚本中做加密处理,再比如说,有的接口的输入参数有一些随机数,每请求一次接口参数值都会发送变化,就可以在前置脚本中编写生成随机数的代码 。 总体来说,就是在请求接口之前对我们的请求数据进行进一步加工处理的都可以使用前置脚本这个功能。 接下来通过一个案例来看下该功能是如何使用 ? 案例:
img 实现步骤:
img 总之,这个前置脚本对我们做接口测试也非常有用,对一些复杂的场景,都可以使用前置脚本进行处理后再请求接口 。 「9. 接口关联」 在我们测试的接口中,经常出现这种情况 。上一个接口的返回数据是下一个接口的输入参数 ,那么这俩个接口就产生了关联。这种关联在做接口测试时非常常见,那么在postman中,如何实现这种关联关系呢 ? 实现思路:
案例:
而图像预览接口URL为: http://localhost/public/upload/user//head_pic//ba51d1c2f7f7b98dfb5cad90846e2d79.jpg 。可以看出这个接口的URL后半部分其实是上一个接口返回的url的值 。那么这俩个接口就产生了关联。那么在postman 可以通过以下三步完成这俩个接口的关联实现 。 实现步骤:
img 可以看出,接口的关联的解决方案都是用的是变量中的知识,也就是说只要你明确了要提取的值,后面就是保存该值,然后在其他接口使用该值就可以了。 「10.常见返回值获取」 在做接口测试时,请求接口返回的数据都是很复杂的json数据,有着多层嵌套,这样的数据层级在postman怎么获取呢 ? 案例1:多层json嵌套, 获取user_id的值
案例2:json中存在列表,获取points中的第二个元素
案例3:列表中取最后一个元素
绵薄之力最后感谢每一个认真阅读我文章的人,看着粉丝一路的上涨和关注,礼尚往来总是要有的,虽然不是什么很值钱的东西,如果你用得到的话可以直接拿走 ? 面试资料我们学习软件测试必然是为了找到高薪的工作,下面这些面试题是来自阿里、腾讯、字节等一线互联网大厂最新的面试资料,并且有阿里大佬给出了权威的解答,刷完这一套面试资料相信大家都能找到满意的工作 ? ? ?这些资料,对于想进阶【自动化测试】的朋友来说应该是最全面最完整的备战仓库,这个仓库也陪伴我走过了最艰难的路程,希望也能帮助到你!凡事要趁早,特别是技术行业,一定要提升技术功底。希望对大家有所帮助……. |
|
|
上一篇文章 下一篇文章 查看所有文章 |
|
开发:
C++知识库
Java知识库
JavaScript
Python
PHP知识库
人工智能
区块链
大数据
移动开发
嵌入式
开发工具
数据结构与算法
开发测试
游戏开发
网络协议
系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程 数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁 |
360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年11日历 | -2024/11/25 20:47:19- |
|
网站联系: qq:121756557 email:121756557@qq.com IT数码 |