『Postman入门万字长文』| 从工具简介、环境部署、脚本应用、Collections使用到接口自动化测试详细过程

『Postman入门万字长文』| 从工具简介、环境部署、脚本应用、Collections使用到接口自动化测试详细过程

  • 1 Postman工具简介
  • 2 Postman安装
  • 3 Postman界面说明
  • 4 一个简单请求
    • 4.1 请求示例
    • 4.2 请求过程
  • 5 Postman其他操作
    • 5.1 import
    • 5.2 History
    • 5.3 Environment
    • 5.4 Global
    • 5.5 其他变量
  • 6 如何在postman中使用脚本?
    • 6.1 Pre-request Script和Tests
    • 6.2 pm.info
    • 6.3 pm.globals
    • 6.4 pm.environment
    • 6.5 pm.variables
    • 6.6 pm.request
    • 6.7 pm.response
    • 6.8 pm.response.to-划重点:这个其实就是断言处理
  • 7 Collections应用
    • 7.1 Collections简介
    • 7.2 Collections创建
    • 7.3 如何实现Collections共享?
    • 7.4 如何管理Collections?
    • 7.5 如何导入导出文件?
    • 7.6 Collections运行

1 Postman工具简介

  • 工具官网信息,请直接搜索即可,这里不赘述:
    在这里插入图片描述
  • Postman是一个比较流行的、功能强大的可完成网页调试和模拟发送HTTP请求的工具或者插件;
  • 主要使用人员比较广,像测试做接口测试,开发进行前后端数据调试等;
  • 一些功能和优点:

①不仅可以用做chrome的插件,而且可以进行独立安装使用;
②只要登陆后,所有的历史请求数据都可以进行自动同步;
③使用本地化安装后的Postman工具比较强大,且基本都是免费的。
④支持跨平台MAC、Windows、Linux等。

2 Postman安装

  • 直接进入postman官网;
  • 选择对应的平台下载即可,本位是windows平台:
    在这里插入图片描述
  • 按照步骤一步一步进行安装即可;
  • 安装完会进入登陆页面,这个看个人需要,需要需要记住历史数据,可以登陆,否则直接进入工具即可。

3 Postman界面说明

  • 进入到主界面后,点击【NEW】会有如下界面:
    在这里插入图片描述
  • 可以看到有几个选项卡,说明如下:
选项卡说明
Create New请求创建、集合的创建以及环境变量的创建等
Templates模板配置,不设置即为默认配置
API Network网络上的公共API可参考

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

4 一个简单请求

4.1 请求示例

  • 我们继续使用禅道的一个接口,如下:
    在这里插入图片描述
  • 请求数据为:
# url:http://127.0.0.1/zentao/api.php/v1/对应API接口名称

data = {"account": "admin", "password": "ZenTao123456"}

4.2 请求过程

  • 创建一个Request请求;
    在这里插入图片描述
  • 填写请求名,请求描述,点击【save】,即可创建一个文件夹:
    在这里插入图片描述
  • 填写请求方式和请求地址:
    在这里插入图片描述
  • 填写请求头部信息(根据实际接口数据填写):
    在这里插入图片描述
  • 填写请求body体,注意数据格式:
    在这里插入图片描述
  • 点击【send】查看返回信息:
    在这里插入图片描述

5 Postman其他操作

5.1 import

  • 如图有个import按钮:
    在这里插入图片描述

  • 这个功能主要是导入其它的已经导出的postman的脚本;
    在这里插入图片描述

  • 导出的文件一般都是Json格式的,我们直接点击图中的【Upload Files】导入即可;

  • 如果是导入多个脚本,我们可以从指定的文件夹导入,点击【Folder】即可;
    在这里插入图片描述

  • 如果是从云共享导入,直接点击【Link】,输入对应的URlAPI-KEY授权的URL
    在这里插入图片描述

  • 导入后会在左侧的【Collections】中显示:
    在这里插入图片描述

5.2 History

  • History其实就是接口请求的历史数据,即使用postman请求过的数据都会在这显示;
    在这里插入图片描述

  • 然后点击左侧列表中的历史接口,详细信息会显示在右侧:
    在这里插入图片描述

5.3 Environment

  • Environment主要是用来设置当前Request发送时的使用环境;
    在这里插入图片描述

  • 这里的环境设置其实就是一些key-value

  • 我们点击图中的环境管理按钮,即可进入环境的设置界面:
    在这里插入图片描述
    在这里插入图片描述

  • 点击【Add】可以新增一些环境信息;
    在这里插入图片描述

  • 设置后可以在请求中直接引用变量,方法是{{变量名}}。先需要切换环境,然后在参数中直接引用,如下:

# 环境切换为:login_url
# 请求地址的ip使用如下:http://{{ip}}/v1/tokens

在这里插入图片描述

5.4 Global

  • 单击图中的图标可以看到选择的Environment以及其他的Global中的变量:
    在这里插入图片描述
    在这里插入图片描述
  • 关于EnvironmentGlobal区别是Environment可以保存多个,而Global只能保存一组数据;保留在Global中的key-value可以被所有的请求使用,但是一个请求只能选择一个Environment
    在这里插入图片描述
  • 我们引用下Global中变量试试:
    在这里插入图片描述

5.5 其他变量

  • 除了以上两个EnvironmentGlobal变量外,还有local、data、Collection变量;
  • Collection变量在 collection中设置,在当前的Collection中生效;
  • data变量表示的是引用外部文件,比如CSVJSON文件等等,主要用于参数化;
  • local变量是在本地生效;
  • 关于变量的作用域可以这么表示下(手画的~~~):
    在这里插入图片描述

6 如何在postman中使用脚本?

6.1 Pre-request Script和Tests

  • 在图中可以看到Pre-request ScriptTests这两个选项是需要设置脚本的;
    在这里插入图片描述
  • Pre-request Script表示请求之前需要执行的脚本;
  • Tests表示请求之后需要执行的脚本;
  • 点击对应的选项,右侧会显示常用的脚本设置,点击后可直接生成对应的脚本;
    在这里插入图片描述

6.2 pm.info

  • 脚本设计主要是基于pm对象,通过这个对象可获取到正在执行脚本的所有信息;
  • 比如可访问正在发送请求的副本信息、响应信息、变量信息等等;
  • pm.info对象是获取正在执行的脚本的相关信息,具体如下:
方法说明类型
pm.info.eventName脚本是在哪个脚本栏中执行的字符串
pm.info.iteration当前运行迭代的次数数值
pm.info.iterationCount计划运行的迭代总次数数值
pm.info.requestName返回请求名字符串
pm.info.requestId返回请求ID字符串
  • 示例如下:
console.log(pm.info.eventName);
console.log(pm.info.requestName);

在这里插入图片描述

6.3 pm.globals

  • 常用的方法如下:
方法说明
pm.globals.has验证是否存在某全局变量
pm.globals.get获取执行全局变量的值
pm.globals.set设置全局变量
pm.globals.unset清除指定的全局变量
pm.globals.toObject将全局变量以对象的方式输出
pm.globals.clear清除全局变量
  • 简单看个示例:
console.log(pm.globals.has("account"));
console.log(pm.globals.get("password"));
console.log(pm.globals.toObject());

在这里插入图片描述

6.4 pm.environment

  • pm.environment环境变量对象,可以获取环境变量信息;
  • 常用方法如下:
方法说明
pm.environment.has检测环境变量是否包含某个变量
pm.environment.get获取环境变量的值
pm.environment.set设置环境变量
pm.environment.unset清除指定的环境变量
pm.environment.toObject将环境变量以对象的方式输出
pm.environment.clear清除环境变量
  • 示例如下:
console.log(pm.environment.has("account"));
console.log(pm.environment.get("password"));
console.log(pm.environment.toObject());

在这里插入图片描述

6.5 pm.variables

  • pm.variables也是变量,不同于全局和环境变量,变量的优先级为迭代数据<环境变量<全局变量;
  • 常用方法是:pm.variables.get获取变量中的某个值;
  • 示例如下:
console.log(pm.variables.get("account"));

在这里插入图片描述

6.6 pm.request

  • pm.request对象获取请求对象;
  • Pre-request Scriptpm.request对象表示将要发送的请求;
  • Tests中的pm.request对象表示上一个发送的请求;
  • 常用方法:
方法说明
pm.request获取当前发送请求的全部headers
pm.request.url获取当前发送请求的url
pm.request.headers以数组的方式返回当前请求中的headers
  • 示例如下:
console.log(pm.request);
console.log(pm.request.url);
console.log(pm.request.headers);

在这里插入图片描述

6.7 pm.response

  • pm.response对象获取响应信息;
  • 常用方法如下:
方法说明
pm.response.code请求返回的状态码
pm.response.reason()当前请求成功返回OK
pm.response.headers请求成功后的responseheaders
pm.response.responseTime获取请求时间
pm.response.text()以文本的方式获取响应中的body
pm.response.json()将body中的内容解析为json对象
  • 示例如下:
console.log(pm.response.code);
console.log(pm.response.reason());
console.log(pm.response.headers);
console.log(pm.response.responseTime);
console.log(pm.response.text());

在这里插入图片描述

6.8 pm.response.to-划重点:这个其实就是断言处理

  • pm.response.to对象主要是完成用例的断言操作;
  • 有两种方式:hava对象和be对象;
  • hava对象常用方法如下:
方法说明
pm.response.to.have.status(code:Number)根据状态码判断响应是否成功
pm.response.to.have.status(reason:String)根据返回的状态值判断
pm.response.to.have.header(key:String)根据response中的headerskey判断
pm.response.to.have.header(key:String,optionalValue:String)根据response中的headerskeyvalue判断
pm.response.to.have.body()返回的数据
pm.response.to.have.body(optionalValue:String)根据响应返回的body内容判断
pm.response.to.have.body(optionalValue:RegExp)根据响应返回的body进行正则判断
pm.response.to.have.body(optionalValue:JSON)根据响应返回的body是否为json进行判断
  • be对象常用方法:
方法说明
pm.response.to.be.info响应码是否为1XX,是为真,否为假
pm.response.to.be.success响应码是否为2XX,是为真,否为假
pm.response.to.be.redirection响应码是否为3XX,是为真,否为假
pm.response.to.be.clientError响应码是否为4XX,是为真,否为假
pm.response.to.be.serverError响应码是否为5XX,是为真,否为假
pm.response.to.be.error响应码是否为4XX或5XX,是为真,否为假
pm.response.to.be.ok响应码是否为200,是为真,否为假
pm.response.to.be.accepted响应码是否为202,是为真,否为假
pm.response.to.be.badRequest响应码是否为400,是为真,否为假
pm.response.to.be.unauthorized响应码是否为401,是为真,否为假
pm.response.to.be.forbidden响应码是否为403,是为真,否为假
pm.response.to.be.notFound响应码是否为404,是为真,否为假
pm.response.to.be.rateLimited响应码是否为429,是为真,否为假
  • 示例如下:
pm.test(
    "状态码是201",function(){
        pm.response.to.have.status(201);
    }
);

在这里插入图片描述

这里需要特别注意:
1、以上这些方法不能直接在脚本写,需要引用一些函数;
2、完成断言的函数主要为:test和expect;
3、语法为:
pm.test("testName", specFunction)
pm.expect(assertion:*)

7 Collections应用

7.1 Collections简介

  • Collections主要是对请求的分组和分类;
  • 可将项目中的每个事件业务流串起来,或将相关的模块分类,保存在集合中,方便维护和管理。

7.2 Collections创建

  • 即就是创建集合,方便寻找、管理、执行和导出等操作;

  • 创建方式一:点击【New】-【Collections】即可:
    在这里插入图片描述

  • 创建方式二:左侧栏-【Collections】-【New Collections】:
    在这里插入图片描述

  • 参数说明:
    在这里插入图片描述

参数说明
Name集合名称
Description集合描述
Authorization授权类型
Pre-request Script运行集合前需要执行的脚本
Tests集合运行后需要执行的脚本
Variables将变量添加到集合中

7.3 如何实现Collections共享?

  • 可以通过团队空间共享Collections
  • 创建好的Collections-右键-【Share Collection】:
    在这里插入图片描述
  • 注意:这个功能需要注册一个postman账号才能用,按照提示注册就行了,进入如下界面:
    在这里插入图片描述
  • 选择分享空间和团队,点击【Share and Continue】即可。

7.4 如何管理Collections?

  • 集合的浏览:左侧栏直接点击即可:
    在这里插入图片描述
  • 集合收藏:选择图中的符号后,就会进行收藏并置顶显示:
    在这里插入图片描述
  • 集合搜索:直接切换到Collections页面搜索栏搜索即可:
    在这里插入图片描述
  • 集合删除:选择结合后边的三个点,点击【delete】即可:
    在这里插入图片描述
  • 结合添加文件夹:点击集合后的三个点,点击【Add Folder】即可。

7.5 如何导入导出文件?

  • 导出Collection文件:选择集合-右键-【Export】:
    在这里插入图片描述
  • 导出和导入Environment文件:请求主界面-右键-【Manage Environment】:
    在这里插入图片描述
    在这里插入图片描述
  • Globals文件导出:在以上操作界面点击【Globals】-【Download as JSON】即可:
    在这里插入图片描述

7.6 Collections运行

  • 点击【Runner】进入运行界面,参数说明如下:
    在这里插入图片描述
  • 点击运行如下:
    在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/187188.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

RK3399 板子烧录Armbian

本来不想写在CSDN这里的。帮有需要的同学了吧。 板子上面标记型号为&#xff1a; GC18-108-RK3399-V2.0TEAN E120339 94V-OML1没有HDMI接口&#xff08;我也是汗&#xff0c;买的时候注意到&#xff0c;坑了&#xff09;&#xff0c;配置信息。 CPU : RK3399RAMROM: 4G16G无…

NX二次开发UF_CURVE_ask_combine_curves 函数介绍

文章作者&#xff1a;里海 来源网站&#xff1a;https://blog.csdn.net/WangPaiFeiXingYuan UF_CURVE_ask_combine_curves Defined in: uf_curve.h int UF_CURVE_ask_combine_curves(tag_t combine_curve_feature, tag_t * first_curve_tag, UF_CURVE_combine_curves_directi…

前车之鉴: 适用于所有select选择框的 全选反选逻辑,如何只用单个change事件优雅完成

文章目录 实际效果1.1 效果展示1.2 核心功能 Show CodeQ & A彩蛋 实际效果 1.1 效果展示 1.2 核心功能 区别网上其他思路&#xff0c;我这里不需要使用原生点击事件&#xff0c;将全选反选逻辑收敛在一个change事件上 此前已经看过一些全选逻辑同学尝试过后&#xff0c;会…

武汉数字孪生赋能工业制造,加速推进制造业数字化转型

随着数字孪生技术的不断推进&#xff0c;互联网、物联网、智能传感技术开始应用到数控机床的远程服务&#xff0c;状态监控&#xff0c;故障诊断&#xff0c;维护管理等方面。武汉数字孪生是在虚拟空间中创建物理对象的高保真虚拟模型&#xff0c;以模拟其在现实世界中的行为提…

【网络】传输层 --- 详解TCP协议

目录 一、协议段格式及其策略确认应答(ACK)机制6个标志位超时重传流量控制滑动窗口1、先谈滑动窗口一般情况2、再谈特殊窗口 拥塞控制拥塞窗口 延迟应答&&捎带应答面向字节流粘包问题 二、三次握手和四次挥手三次握手为什么是3次&#xff1f;不是2、4、5、6次呢 四次挥…

2023.11.25-电商项目建设业务学习1-指标,业务流程,核销

目录 1.指标分类(原子指标,派生指标,衍生指标) 2.一些业务名词 3.四大业务流程-销售需求 3.1-线上线下销售 3.2线上线下退款 4.四大业务流程-会员业务 5.四大业务流程-供应链业务 6.四大业务流程-商城业务 7.核销主题需求分析 1.指标分类(原子指标,派生指标,衍生指标) 原…

C++类与对象(上)

&#x1f389;个人名片&#xff1a; &#x1f43c;作者简介&#xff1a;一名乐于分享在学习道路上收获的大二在校生&#x1f43b;‍❄个人主页&#x1f389;&#xff1a;GOTXX&#x1f43c;个人WeChat&#xff1a;ILXOXVJE&#x1f43c;本文由GOTXX原创&#xff0c;首发CSDN&am…

Spark---SparkCore(一)

一、术语与宽窄依赖 1、术语解释 1、Master(standalone):资源管理的主节点&#xff08;进程&#xff09; 2、Cluster Manager:在集群上获取资源的外部服务(例如&#xff1a;standalone,Mesos,Yarn) 3、Worker Node(standalone):资源管理的从节点(进程)或者说管理本机资源的…

[Docker]十.Docker Swarm讲解

一.Dokcer Swarm集群介绍 1.Dokcer Swarm 简介 Docker Swarm 是 Docker 公司推出的用来管理 docker 集群的工具&#xff0c; 使用 Docker Swarm 可以快速方便的实现 高可用集群 ,Docker Compose 只能编排单节点上的容器, Docker Swarm 可以让我们在单一主机上操作来完成对 整…

C语言—sizeof和strlen的区别

sizeof和strlen的区别 1、两者无联系 2、 sizeof&#xff1a;计算数组&#xff0c;变量&#xff0c;类型所在空间的大小&#xff0c;单位是字节 strlen&#xff1a;求字符串的长度&#xff0c;\0之前的字符个数&#xff0c;只针对字符串求长度 3、sizeof是操作符 strlen是库…

全国甲骨文识读大会用到哪些竞赛软件

2023年&#xff0c;全国甲骨文识读大会第1季在“中华字都安阳”举办&#xff0c;天纵竞赛软件为此次高端知识竞赛提供软件支持。 甲骨文识读大会分为海选、初赛、复赛、决赛4个阶段&#xff0c;不分年龄、性别、职业、地域&#xff0c;并邀请国内甲骨文和殷商文化方面专家学者组…

打破障碍:2024年赋能企业人工智慧生成创新-5个应用场景与6个转型步骤

想要了解如何采用生成式AI来提高企业效率和竞争力&#xff1f;本指南将介绍如何采用生成式AI来实现数字化转型&#xff0c;并打造智能化商业模式。从5大应用场景和6大步骤切入&#xff0c;让您了解如何开启生成式AI创新。立即连线创新专家咨询或观看创新战略方案视频进一步了解…

构建未来:云计算 生成式 AI 诞生科技新局面

目录 引言生成式 AI&#xff1a;开发者新伙伴云计算与生成式 AI 的无缝融合亚马逊云与生成式 AI 结合的展望/总结我用亚马逊云科技生成式 AI 产品打造了什么&#xff0c;解决了什么问题未来科技发展趋势&#xff1a;开发者的机遇与挑战结合实践看未来结语开源项目 引言 2023年…

推荐6款本周 yyds 的开源项目

&#x1f525;&#x1f525;&#x1f525;本周GitHub项目圈选: 主要包含 链接管理、视频总结、有道音色情感合成、中文文本格式校正、GPT爬虫、深度学习推理 等热点项目。 1、Dub 一个开源的链接管理工具&#xff0c;可自定义域名将繁杂的长链接生成短链接&#xff0c;便于保…

ORA-14452: 试图创建, 变更或删除正在使用的临时表中的索引

在编写一个test存储过程中出现一个错误报告:ORA-14452: 试图创建, 变更或删除正在使用的临时表中的索引,代码如下 create or replace PROCEDURE TMP_TRANSCRIPT AS str_sql varchar2(500);v_flag number:0; --标识 begin--判断临时表是否存在SELECT COUNT(*) into v_flag FROM…

vue3(一)-基础入门

一、导入vue.js 1.可以借助 script 标签直接通过 CDN 来使用 Vue <!-- <script src"https://unpkg.com/vue3/dist/vue.global.js"></script> -->2.也可以下载vue.global.js文件并在本地导入 <script src"./lib/vue.global.js">&…

管理类联考——数学——汇总篇——知识点突破——代数——函数——记忆

文章目录 整体文字提炼图像绘画 考点记忆/考点汇总——按大纲 本篇思路&#xff1a;根据各方的资料&#xff0c;比如名师的资料&#xff0c;按大纲或者其他方式&#xff0c;收集/汇总考点&#xff0c;即需记忆点&#xff0c;在通过整体的记忆法&#xff0c;比如整体信息很多&am…

C++ Boost 异步网络编程基础

Boost库为C提供了强大的支持&#xff0c;尤其在多线程和网络编程方面。其中&#xff0c;Boost.Asio库是一个基于前摄器设计模式的库&#xff0c;用于实现高并发和网络相关的开发。Boost.Asio核心类是io_service&#xff0c;它相当于前摄模式下的Proactor角色。所有的IO操作都需…

Android仿 美团 / 饿了么,店铺详情页功能

前言 UI有所不同&#xff0c;但功能差不多&#xff0c;商品添加购物车功能 正在写&#xff0c;写完会提交仓库。 页面主要由&#xff1a;MagicIndicator ViewPager2 Fragment CoordinatorLayout NestedScrollView RecyclerView实现。 效果图一&#xff1a;左右RecyclerV…

【SwiftUI】7.预览及其内部机制

上一篇讲到了组件及组件化&#xff0c;从概念和优/缺点两个方向说明了组件化的意义&#xff0c;更为重要的是&#xff0c;组件和组件化是一个在编程领域&#xff0c;放之四海皆可以的概念&#xff0c;理解和运用它是非常必要的&#xff0c;希望大家能掌握。今天我们介绍另一个特…