Postman:API测试之Postman使用完全指南
Postman
是一个可扩展的API
开发和测试协同平台工具,可以快速集成到CI/CD
管道中。旨在简化测试和开发中的API
工作流。
Postman
工具有Chrome
扩展和独立客户端,推荐安装独立客户端。
Postman
有个workspace
的概念,workspace
分personal
和team
类型。Personal workspace
只能自己查看的API
,Team workspace
可添加成员和设置成员权限,成员之间可共同管理API
。
当然我个人使用一般是不登录的,因为登录之后会自动将你的测试历史数据保存到账户里,你可以登陆网页端进行查看。
因为API
的很多数据是很敏感的,有的含有Token
,或者就是一些私密信息,虽然Postman
自己也强调说这样很安全,不会私下窥探用户的信息之类的,但是呢还是至少做一点有效的防范吧,自己不上传,因为网络并没有绝对的安全。
所以我每次测试之后会将数据(Case
)保存在本地,下次使用或者换设备的情况下将数据拷贝过来又可以继续使用了。
下面正式开始介绍如何使用Postman
吧。
1. 为什么选择Postman
选择使用Postman
的原因如下:
-
简单易用 - 要使用
Postman
,你只需登录自己的账户,只要在电脑上安装了Postman
应用程序,就可以方便地随时随地访问文件。 -
使用集合 -
Postman
允许用户为他们的API
调用创建集合。每个集合可以创建子文件夹和多个请求。这有助于组织测试结构。 -
多人协作 - 可以导入或导出集合和环境,从而方便共享文件。直接使用链接还可以用于共享集合。
-
创建环境 - 创建多个环境有助于减少测试重复(
DEV/QA/STG/UAT/PROD
),因为可以为不同的环境使用相同的集合。这是参数化发生的地方,将在后续介绍。 -
创建测试 - 测试检查点(如验证HTTP响应状态是否成功)可以添加到每个
API
调用中,这有助于确保测试覆盖率。 -
自动化测试 - 通过使用集合
Runner
或Newman
,可以在多个迭代中运行测试,节省了重复测试的时间。 -
调试 -
Postman
控制台有助于检查已检索到的数据,从而易于调试测试。 -
持续集成- 通过其支持持续集成的能力,可以维护开发实践。
2. 如何下载安装Postman
Step1
) 去官网下载进行安装
官网主页:https://www.postman.com/downloads/, 下载所需版本进行安装即可。
Step2
) 登录
安装完成之后会要求你必须登录才能使用,没有账号可以进行注册,注册是免费的。(也可使用Google
账号,不过基本不能登录,你懂的)
Step3
)在Workspace
选择你要使用的工具并点击“Save My Preferences
”保存。
Step4
)你将看到启动后的页面如下
3. 如何使用Postman
下图是Postman
的工作区间,各个模块功能的介绍如下:
New
,在这里创建新的请求、集合或环境;还可以创建更高级的文档、Mock Server
和Monitor
以及API
。Import
,这用于导入集合或环境。有一些选项,例如从文件,文件夹导入,链接或粘贴原始文本。Runner
,可以通过Collection Runner
执行自动化测试。后续介绍。Open New
,打开一个新的标签,Postman
窗口或Runner
窗口。My Workspace
,可以单独或以团队的形式创建新的工作区。Invite
,通过邀请团队成员在工作空间上进行协同工作。History
,所有的历史记录,这样可以很容易地跟踪你所做的操作。Collections
,通过创建集合来组织你的测试套件。每个集合可能有子文件夹和多个请求。请求或文件夹也可以被复制。Request tab
,这将显示您正在处理的请求的标题。默认对于没有标题的请求会显示“Untitled Request
”。HTTP Request
,单击它将显示不同请求的下拉列表,例如:GET
,POST
,COPY
,DELETE
等。在测试中,最常用的请求是GET
和POST
。Request URL
,也称为端点,显示API
的URL
。Save
,如果对请求进行了更改,必须单击save
,这样新更改才不会丢失或覆盖。Params
,在这里将编写请求所需的参数,比如Key - Value
。Authorization
,为了访问api
,需要适当的授权。它可以是Username
、Password
、Token
等形式。Headers
,请求头信息。Body
,请求体信息,一般在POST
中才会使用到。Pre-request Script
,请求之前 先执行脚本,使用设置环境的预请求脚本来确保在正确的环境中运行测试。Tests
,这些脚本是在请求期间执行的。进行测试非常重要,因为它设置检查点来验证响应状态是否正常、检索的数据是否符合预期以及其他测试。Settings
,最新版本的有设置,一般用不到。
4. 如何处理GET
请求
Get
请求用于从指定的URL
获取信息,不会对端点进行任何更改。
在这里我们使用如下的URL
作为演示:
https://jsonplaceholder.typicode.com/users
在Postman
的工作区中:
1、选择HTTP
请求方式为GET
2、在URL
区域输入 链接
3、点击 “Send
”按钮
4、你将看到下方返回200状态码
5、在正文中应该有10个用户结果,表明您的测试已经成功运行。
注意:在某些情况下,Get
请求失败可能由于URL
无效或需要身份验证。
5. 如何处理POST
请求
Post
请求与Get
请求不同,因为存在用户向端点添加数据的数据操作。使用之前GET
请求中相同数据,现在添加我们自己的用户。
Step 1
)创建一个新请求
Step 2
)在新请求中
1、选择HTTP
请求方式为GET
2、在URL
区域输入 链接:https://jsonplaceholder.typicode.com/users
3、切换到Body
选项
Step 3
) Body
选项
1、选中raw
选项
2、选择JSON
Step 4
) 复制前面GET
请求返回的json
内容的第一节
更改id
为11,更改name
以及uesrname
和email
[{"id": 11,"name": "Krishna Rungta","username": "Bret","email": "Sincere@april.biz","address": {"street": "Kulas Light","suite": "Apt. 556","city": "Gwenborough","zipcode": "92998-3874","geo": {"lat": "-37.3159","lng": "81.1496"}},"phone": "1-770-736-8031 x56442","website": "hildegard.org","company": {"name": "Romaguera-Crona","catchPhrase": "Multi-layered client-server neural-net","bs": "harness real-time e-markets"}}
]
注意: 检查Body
里用到的JSON
格式很重要,以确保数据正确。
检测的工具比如:https://jsonformatter.curiousconcept.com/
Step 5
)发送请求
1、完成上述的信息输入,点击Send
按钮
2、Status
:应该是201,显示为创建成功
3、在Body
里返回数据
6. 如何将请求参数化
数据参数化是Postman
最有用的特征之一。你可以将使用到的变量进行参数化,而不是使用不同的数据创建相同的请求,这样会事半功倍,简洁明了。
这些数据可以来自数据文件或环境变量。参数化有助于避免重复相同的测试,可用于自动化迭代测试。
参数通过使用双花括号创建:{{sample}}
。
比如下面的请求:
接下来创建一个参数化get
请求:
Step 1
) 创建一个参数化get
请求
1、将HTTP
请求设置为GET
2、输入URL
: https://jsonplaceholder.typicode.com/users
;将链接的域名部分替换为参数,例如
{{url}}
。请求url
现在应该是{{url}}/users
。
3、点击Send
按钮。
应该没有响应,因为我们没有设置参数的源,如下图:
Step 2
) 使用环境设置所需的参数
1、点击眼睛图标
2、单击Edit
将该变量设置为可在所有集合中使用的全局环境。
Step 3
) 变量–variable
1、将名称设置为url
,该url
为https://jsonplaceholder.typicode.com
2、点击保存按钮
Step 4
) 如果看到下面截图的样式,请单击Close
Step 5
) 回到你的Get
请求页面,然后单击发送Send
按钮,Get
请求应该就会返回结果了,如下图:
注意:请确保所有的参数都有准确的源数据,不管是环境变量还是数据文件,以避免出错。
7. 如何创建Postman Tests
Postman Tests
在请求中添加JavaScript
代码来协助验证结果,如:成功或失败状态、预期结果的比较等等。
通常从pm.test
开始。它可以与断言相比较,验证其他工具中可用的命令。
接下来创建一个包含Tests
的请求:
Step 1
) 创建一个Get
请求
1、切换到Tests
选项,右边是代码片段选项。
2、从右边的代码片段选项里面选中 “Status code: Code is 200
”
3、JS
代码就自动出现在窗口中
Step 2
) 点击发送请求按钮。测试结果就显示出来了,如下图:
Step 3
) 回到Tests
选项卡,让我们添加另一个测试。这次我们将比较预期结果和实际结果。
在右边的SNIPPETS
区域选择“Response body:JSON value check
”选项,我们将检查Leanne Graham
是否拥有userid 1
。
Step 4
)
1、将代码中的“Your Test Name
”替换为“Check if user with id1 is Leanne Graham
”,以便测试名称确切描述我们想测试的内容。
2、使用jsonData[0].name
代替jsonData.value
;获取路径,在获取结果之前检查Body
。因为Leanne Graham
是userid 1
,所以jsonData
在第一个结果中,这个结果应该从0开始。如果你想获得第二个结果,那么对后续结果使用jsonData[1]
即可。
3、在eql
中,输入“Leanne Graham
”
pm.test("Check if user with id1 is Leanne Graham", function () {var jsonData = pm.response.json();pm.expect(jsonData[0].name).to.eql("Leanne Graham");
});
Step 5
) 点击发送请求,可以看到你的请求之后测试结果中有两项显示测试通过。
注意: 有不同种类的测试可以在Postman
中创建。尝试探索这个工具,看看哪些测试适合你实际测试。
8. 如何创建测试集合
集合在组织测试套件中扮演着重要的角色。它可以被导入和导出,使得在团队之间共享集合变得很容易。在本教程中,我们将学习如何创建和执行集合。
Step 1
) 单击页面左上角的New
按钮,如下图:
Step 2) 选择Collection
(集合),创建collection
窗口弹出,如下图:
Step 3
) 输入所需的集合名称和描述,然后单击create
。
现在已经创建了一个集合。
Step 4
) 和前面的Get
请求一样,点击保存。
Step5
)
1、选择Postman
测试集合(Test Collection
)
2、点击保存Postman Test Collection
Step 6
) Postman test collection
现在应该包含了一个请求,如下图:
Step 7
) 重复上述的Step4-5
,继续创建请求,这样,测试集合就应该有2个请求了,如下图:
9. 如何使用Collection Runner
运行集合
有两种方式来运行一个集合,即Collection Runner
和Newman
。
9.1.Collection Runner
Step 1
) 单击页面顶部导入按钮旁边的Runner
按钮,如下图:
Step 2
)Collection Runner
页面应该出现如下所示。以下是对各个字段的描述
Step 3
) 做如下设置,运行你的测试集合
-
选择
Postman
测试集合-集合迭代次数为3 -
设置延迟为2500毫秒
-
点击
Start Run
按钮
Step 4
) 单击Run
按钮后将显示Run
结果页。根据延迟的不同,你应该在测试执行的同时看到显示的结果。
1、一旦测试完成,你就可以看到测试状态是通过还是失败,以及每个迭代的结果。
2、你将看到Get
请求的Pass
状态;
3、由于我们没有任何Post
测试,所以应该会出现请求没有任何测试的消息。
可以出在请求中进行测试是多么重要,这样你就可以验证HTTP
请求状态是否成功,以及是否创建或检索了数据。
9.2 如何使用Newman运行集合
运行集合的另一种方式是通过Newman
。Newman
和Collection Runner
之间的主要区别如下:
1、Newman
是Postman
的替代品,所以需要单独安装Newman
;
2、Newman
使用命令行,而Collection Runner
使用UI
界面;
3、Newman
可以用于持续集成。
安装Newman
并运行Collection
,步骤如下:
Step 1
) 下载并安装NodeJs
: http://nodejs.org/download/
Step 2
) 打开命令行窗口并输入下面命令:
npm install -g newman
安装后如下图:
Step 3
)
Newman
安装好之后,让我们回到Postman
的workspace
。在Collections
框中,单击三个点 ...
会出现新的选择选项,可看到Export
选项,如下图:
Step 4
)
选择导出集合,默认使用推荐的集合版本,比如此处是v2.1
,然后单击导出:
Step 5
)
选择你想要保存的地址之后点击保存,这里建议专门新建一个文件夹来存放你的Postman tests
。
Step 6
)
另外还需要导出我们的环境(enviroment
)。单击全局环境下拉菜单旁边的eye
图标,选择JSON
格式下载。选择你想要的位置,然后单击Save
。最好将环境放在与Step5
导出的集合相同的文件夹中。
Step 7
)
导出Environment
到集合文件夹后,现在回到命令行,将目录更改为保存集合和环境的位置。
cd C:\Users\Asus\Desktop\Postman Tests
Step 8
)
使用下面的命令运行你的测试集合:
newman run PostmanTestCollection.postman_collection.json -e Testing.postman_globals.json
运行的结果应该如下图:
关于Newman
的一些基础指导如下:
1、只运行集合(如果没有环境或测试数据文件依赖关系,则可以使用此选项)
newman run <collection name>
2、运行集合和环境(参数-e
是environment
)
newman run <collection name> -e <environment name>
3、使用所需的编号运行集合的迭代
newman run <collection name> -n <no.of iterations>
4、运行数据文件
newman run <collection name> --data <file name> -n <no.of iterations> -e <environment name>
5、设置延迟时间
(这一点很重要,因为如果由于请求在后台服务器上,完成前一个请求时没有延迟时间直接启动下一个请求,测试可能会失败。)
newman run <collection name> -d <delay time>
相关文章:

Postman:API测试之Postman使用完全指南
Postman是一个可扩展的API开发和测试协同平台工具,可以快速集成到CI/CD管道中。旨在简化测试和开发中的API工作流。 Postman工具有Chrome扩展和独立客户端,推荐安装独立客户端。 Postman有个workspace的概念,workspace分personal和team类型…...

Flume学习笔记(3)—— Flume 自定义组件
前置知识: Flume学习笔记(1)—— Flume入门-CSDN博客 Flume学习笔记(2)—— Flume进阶-CSDN博客 Flume 自定义组件 自定义 Interceptor 需求分析:使用 Flume 采集服务器本地日志,需要按照日志…...

go的字符切片和字符串互转
Go 1.21 // 返回一个Slice,它的底层数组自ptr开始,长度和容量都是len func Slice(ptr *ArbitraryType, len IntegerType) []ArbitraryType // 返回一个指针,指向底层的数组 func SliceData(slice []ArbitraryType) *ArbitraryType // 生成一…...

所见即所得的动画效果:Animate.css
我们可以在集成Animate.css来改善界面的用户体验,省掉大量手写css动画的时间。 官网:Animate.css 使用 1、安装依赖 npm install animate.css --save2、引入依赖 import animate.css;3、在项目中使用 在class类名上animate__animated是必须的&#x…...

ERR:Navicat连接Sql Server报错
错误信息:报错:未发现数据源名称并且未指定默认驱动程序。 原因:Navicat没有安装Sqlserver驱动。 解决方案:在Navicat安装目录下找到sqlncli_x64.msi安装即可。 一键安装即可。 Navicat链接SQL Server配置 - MarchXD - 博客园 …...

python算法例10 整数转换为罗马数字
1. 问题描述 给定一个整数,将其转换为罗马数字,要求返回结果的取值范围为1~3999。 2. 问题示例 4→Ⅳ,12→Ⅻ,21→XⅪ,99→XCIX。 3. 代码实现 def int_to_roman(num):val [1000, 900, 500, 400,100, 90, 50, 40…...

springboot引入第三方jar包放到项目目录中,添加web.xml
参考博客:https://www.cnblogs.com/mask-xiexie/p/16086612.html https://zhuanlan.zhihu.com/p/587605618 1、在resources目录下新建lib文件夹,将jar包放到lib文件夹中 2、修改pom.xml文件 <dependency><groupId>com.lanren312</grou…...

大数据研发工程师课前环境搭建
大数据研发工程师课前环境搭建 第一章 VMware Workstation 安装 在Windows的合适的目录来进行安装,如下图 1.1 双击打开 1.2 下一步,接受协议 1.3 选择安装位置 1.4 用户体验设置 1.5 快捷方式 已经准备好安装,点击安装 1.6 安装中 1.7 安装…...

Qt图形视图框架:QGraphicsItem详解
Qt图形视图框架:QGraphicsItem详解 Chapter1 Qt图形视图框架:QGraphicsItem详解Chapter2 自定义QGraphicsItem实现平移、改变尺寸和旋转1. 平移2. 改变尺寸3. 旋转完整代码如下:头文件源文件 Chapter1 Qt图形视图框架:QGraphicsIt…...

defer和async
如果两个属性浏览器都不兼容,推荐把<script>标签放到底部 一般情况下,浏览器在解析html源文件时,如果遇到外部的<script>标签,解析过程就会先暂停,这时会对script进行加载,执行两个过程&…...

数电实验-----实现74LS139芯片扩展为3-8译码器以及应用(Quartus II )
目录 一、74LS139芯片介绍 芯片管脚 芯片功能表 二、2-4译码器扩展为3-8译码器 1.扩展原理 2.电路图连接 3.仿真结果 三、3-8译码器的应用(基于74ls139芯片) 1.三变量表决器 2.奇偶校验电路 一、74LS139芯片介绍 74LS139芯片是属于2-4译码器…...

洋葱架构、三层架构及两者区别
前言 洋葱架构它的名称来源于洋葱的层次结构,即软件代码的各层次之间的关系。在这种架构中,应用程序的各个组件通过一系列层次结构被逐层包裹在一起,形成一个类似于洋葱的结构。 一、经典三层架构 三层架构是一种软件设计模式,…...

JavaEE进阶学习:Spring 的创建和使用
Spring 就是⼀个包含了众多工具方法的 IoC 容器。既然是容器那么它就具备两个最基本的功能: 将对象存储到容器(Spring)中从容器中将对象取出来 接下来使用 Maven 方式来创建一个 Spring 项目,创建 Spring 项目和 Servlet 类似&a…...

音视频项目—基于FFmpeg和SDL的音视频播放器解析(十四)
介绍 在本系列,我打算花大篇幅讲解我的 gitee 项目音视频播放器,在这个项目,您可以学到音视频解封装,解码,SDL渲染相关的知识。您对源代码感兴趣的话,请查看基于FFmpeg和SDL的音视频播放器 如果您不理解本…...

Tomcat无法映射到activiti-app导致activiti无法启动页面
原因之一:JDK版本与Tomcat版本不匹配,jdk8 yyds 我使用的是JDK11,Tomcat是9.0的,都是最新的,但还是不行,最后JDK改为8,tomcat的cmd后台没有报错,activiti-pp也可以正常访问了,很神奇…...

c语言常见的面试问题
在C语言编程中,面试官可能会询问你以下一些常见问题: 什么是C语言? C语言是一种通用的、过程式的计算机编程语言,由Dennis Ritchie在1972年创建。它是Unix操作系统的核心语言,也是许多其他编程语言(如Go、…...

image图片之间的间隙消除
多个图片排列展示,水平和垂直方向的间隔如何消除 垂直方向 vertical-align 原因: vertical-align属性主要用于改变行内元素的对齐方式,行内元素默认垂直对齐方式是基线对齐(baseline) 这是因为图片属于行内元素&…...

asp.net心理健康管理系统VS开发sqlserver数据库web结构c#编程计算机网页项目
一、源码特点 asp.net 心理健康管理系统 是一套完善的web设计管理系统,系统具有完整的源代码和数据库,系统主要采用B/S模式开发。 系统视频链接 https://www.bilibili.com/video/BV19w411H7P4/ 二、功能介绍 本系统使用Microsoft Visual Studio…...

CnosDB有主复制演进历程
分布式存储系统的复杂性涉及数据容灾备份、一致性、高并发请求和大容量存储等问题。本文结合CnosDB在分布式环境下的演化历程,分享如何将分布式理论应用于实际生产,以及不同实现方式的优缺点和应用场景。 分布式系统架构模式 分布式存储系统下按照数据复…...

【前沿学习】美国零信任架构发展现状与趋势研究
转自:美国零信任架构发展现状与趋势研究 摘要 为了应对日趋严峻的网络安全威胁,美国不断加大对零信任架构的研究和应用。自 2022 年以来,美国发布了多个零信任战略和体系架构文件,开展了多项零信任应用项目。在介绍美国零信任战略…...

Toolformer论文阅读笔记(简略版)
文章目录 引言方法限制结论 引言 大语言模型在zero-shot和few-shot情况下,在很多下游任务中取得了很好的结果。大模型存在的限制:无法获取最新的信息、无法进行精确的数学计算、无法理解时间的推移等。这些限制可以通过扩大模型规模一定程度上解决&…...

Pytorch torch.dot、torch.mv、torch.mm、torch.norm的用法详解
torch.dot的用法: 使用numpy求点积,对于二维的且一个二维的维数为1 torch.mv的用法: torch.mm的用法 torch.norm 名词解释:L2范数也就是向量的模,L1范数就是各个元素的绝对值之和例如:...

Jave 定时任务:使用Timer类执行定时任务为何会发生任务阻塞?如何解决?
IDE:IntelliJ IDEA 2022.2.3 x64 操作系统:win10 x64 位 家庭版 JDK: 1.8 文章目录 一、Timer类是什么?二、Timer类主要由哪些部分组成?1.TaskQueue2. TimerThread 三、示例代码分析四、自定义TimerTask为什么会发生任务相互阻塞的…...

Visual Studio Code配置c/c++环境
Visual Studio Code配置c/c环境 1.创建项目目录2.vscode打开项目目录3.项目中添加文件4.文件内容5.配置编译器6.配置构建任务7.配置调试设置 1.创建项目目录 d:\>mkdir d:\c语言项目\test012.vscode打开项目目录 3.项目中添加文件 4.文件内容 #include <iostream> u…...

漏洞利用工具的编写
预计更新网络扫描工具的编写漏洞扫描工具的编写Web渗透测试工具的编写密码破解工具的编写漏洞利用工具的编写拒绝服务攻击工具的编写密码保护工具的编写情报收集工具的编写 漏洞利用工具是一种常见的安全工具,它可以利用系统或应用程序中的漏洞来获取系统权限或者窃…...

ChatGPT之父被OpenAI解雇
首席技术官 Mira Murati 任命临时首席执行官领导 OpenAI;山姆阿尔特曼(Sam Altman)离开公司。 阿尔特曼先生的离职是在董事会经过深思熟虑的审查程序之后进行的,审查程序得出的结论是,他在与董事会的沟通中始终不坦诚…...

linux中利用fork复制进程,printf隐藏的缓冲区,写时拷贝技术,进程的逻辑地址与物理地址
1.prinf隐藏的缓冲区 1.思考:为什么会有缓冲区的存在? 2.演示及思考? 1).演示缓存区没有存在感 那为什么我们感觉不到缓冲区的存在呢?我们要打印东西直接就打印了呢? 我们用代码演示一下: 比如打开一个main.c,输入内容如下: #include <stdio.h>int main(){printf…...

java游戏制作-拼图游戏
一.制作主界面 首先创建一个Java项目命名为puzzlegame 结果:】 二.设置界面 代码: 三.初始化界面 代码: 优化代码: 四.添加图片 先在Java项目中创建图片文件夹,将图片导入其中 管理图片: 五.打乱图片顺序...

使用sklearn报AttributeError: ‘NoneType‘ object has no attribute ‘split‘
错误原因 在使用scikit-learn的时候报AttributeError: NoneType object has no attribute split Exception ignored on calling ctypes callback function: <function _ThreadpoolInfo._find_modules_with_dl_iterate_phdr..match_module_callback at 0x7fb757978160> T…...

C++学习 --map
目录 1, 什么是map 2, 创建map 2-1, 标准数据类型 2-2, 自定义数据类型 2-3, 其他创建方式 3, 操作map 3-1, 赋值 3-2, 插入元素(insert) 3-2-1, 插入标准数据类…...