当前位置: 首页 > article >正文

【玩转 Postman 接口测试与开发2_015】第12章:模拟服务器(Mock servers)在 Postman 中的创建与用法(含完整实测效果图)

book cover for the 2nd version

《API Testing and Development with Postman》最新第二版封面

文章目录

  • 第十二章 模拟服务器(Mock servers)在 Postman 中的创建与用法
    • 1 模拟服务器的概念
    • 2 模拟服务器的创建
      • 2.1 开启侧边栏
      • 2.2 模拟服务器的两种创建方式
      • 2.3 私有模拟器的 API 秘钥的用法
    • 3 常见的模拟服务器用法演示
      • 3.1 Mock 服务器的工作原理
      • 3.2 模拟 GET 请求:生成指定的响应内容
      • 3.3 模拟报 500 错误码的请求
      • 3.4 模拟路径参数
      • 3.5 模拟从请求 JSON 中提取信息
      • 3.6 模拟 PUT 请求
      • 3.7 模拟第三方接口返回随机数据

写在前面
本章主要介绍了 Postman 中的模拟服务器(mock server)的基本用法。时隔四年,当初的操作界面和设置流程已经大大简化了,掌握了本章介绍的基本用法,再结合 Postman 官方文档的强大加持,模拟服务器这块基本可以在工作中胜任了。

第十二章 模拟服务器(Mock servers)在 Postman 中的创建与用法

本章概要

  • 模拟服务器的概念
  • Postman 创建模拟服务器的方法
  • Postman 设置模拟数据的方法

Postman 中的模拟服务器(mock server)经过不断地完善,现在已经比刚推出时好用很多了。本章内容看似很多,其实核心知识点只有几个。重点把握模拟服务器的工作原理和常见的数据模拟方法即可。


1 模拟服务器的概念

基本概念

  • 本书中的模拟服务器(mock server),特指 API 接口的模拟服务器;
  • 主要用途:模拟真实 API 服务器,可返回预设的 硬编码 响应。
  • 既可以模拟单一端点(简单),也可以模拟多个端点(复杂),复杂程度取决于要测试的目标。

Mock 服务器的常见应用场景:

  1. 目标应用引入了第三方 API,但又不想为了测试专门去调该接口;
  2. 前端需要测试,但后端接口尚未就绪时;
  3. 进行与后端隔开的 UI 测试时(假设架构支持),通过 Mock 服务器提高测试速度与稳定性;
  4. 需要模拟特定错误场景来测试前端的响应时。

其他注意事项:

  • Mock 服务器需要定期更新,以保持与真实服务的一致性。
  • 要确保模拟数据的准确性,避免测试结果出现偏差。
  • Postman 对普通用户仅提供每月累计 1000 次的模拟服务器总调用额度(注意:是对所有服务器的总调用次数),想要更多调用次数只能开通会员,或者换用其他免费帐号。

2 模拟服务器的创建

2.1 开启侧边栏

首先开启 Mock servers 侧边栏:

图 12.1 点击侧边栏配置图标,并开启 Postman 模拟服务器侧边栏

【图 12.1 点击侧边栏配置图标,并开启 Postman 模拟服务器侧边栏】

2.2 模拟服务器的两种创建方式

创建模拟服务器的方法主要有 两种

  1. 从专门的 Mock servers 侧边栏创建:

    img12.3

  2. Collection 测试集合中创建:

    img12.2

具体创建根据界面提示进行即可,都没有什么难度。

书中演示的是第一种,并且是从同步创建一个新的 Collection 集合开始:

图 12.2 Postman 模拟服务器创建页面详解

【图 12.2 Postman 模拟服务器创建页面详解】

2.3 私有模拟器的 API 秘钥的用法

最后一项可将该模拟服务器变为私有服务器,除非提供有效的 API 秘钥,否则任何人都无法访问。API 秘钥通过个人帐号的设置页(https://web.postman.co/settings/me/api-keys)创建:

图 12.3 设置私有模拟服务器时需要的 API 秘钥的创建页面截图

【图 12.3 设置私有模拟服务器时需要的 API 秘钥的创建页面截图】

创建好后,将秘钥存为一个变量(如 api_key),然后在测试请求的 Authorization 标签作如下配置即可:

图 12.4 用于访问私有模拟服务器的 API 秘钥的具体用法示例

【图 12.4 用于访问私有模拟服务器的 API 秘钥的具体用法示例】

3 常见的模拟服务器用法演示

3.1 Mock 服务器的工作原理

按照刚才的流程创建出 Mock 服务器后,Postman 会自动生成一个同名的 Collection 测试集合,并在该集合下创建一个名为 url 的变量存放其基础 URL,操作起来很轻松(Mock serverCollection 尽管同名,但各自的图标有所不同):

图 12.5 创建好 Mock 服务器后,Postman 会自动创建同名集合与 url 变量

【图 12.5 创建好 Mock 服务器后,Postman 会自动创建同名集合与 url 变量】

Postman 中使用 Mock 服务器,其实就是通过对 请求示例 的各种配置,实现各种想要的 响应效果

图 12.8 在 Postman 使用 Mock 服务器的基本流程

【图 12.8 在 Postman 使用 Mock 服务器的基本流程】

3.2 模拟 GET 请求:生成指定的响应内容

通过修改请求示例的状态码和响应正文(Body),可以模拟想要的响应内容:

图 12.9 修改请求示例的响应内容截图

【图 12.9 修改请求示例的响应内容截图】

注意,修改示例后 一定要保存,否则修改内容无法生效

另外,响应正文的 JSON 代码也支持 Alt + Shift + F 格式化,与 VSCode 一致,非常贴心。

3.3 模拟报 500 错误码的请求

除了模拟正常情况,还可以新增一个示例,模拟请求报 500 错误的情况。方法只需两步:

  1. 新建一个示例(Example),状态码改为 500,响应内容自拟;
  2. 在测试请求的请求头添加 x-mock-response-code 属性,值设为 500 即可;

示例的设置如下:

img12.10

对应的请求设置及测试结果如下:

img12.11

3.4 模拟路径参数

需求:从路径中获取 task_id,并将该信息放入响应正文中。

方法:

  1. 定义示例:

    1. URL 改为 {{url}}/tasks/{{task_id}}

    2. 状态码暂定 200;

    3. 在响应正文中通过以下语法引用 task_id

      {"description":"Mock Task {{task_id}}","status":"Draft"
      }
      
  2. 修改测试请求:URL 直接写 {{url}}/tasks/{{task_id}} 即可。

实测情况:

图 12.10 路径参数的定义和获取该参数的写法示例

【图 12.10 路径参数的定义和获取该参数的写法示例】

图 12.11 实测请求参数的定义与捕获情况(符合预期)

【图 12.11 实测请求参数的定义与捕获情况(符合预期)】

3.5 模拟从请求 JSON 中提取信息

需求:从创建待办事项的 POST 请求体 JSON 中,提取 descriptionstatus 字段信息,并作为响应内容的一部分。

方法:

  1. 创建一个名为 Create TaskPOST 请求:URL 设为 {{url}}/tasks,状态栏填 201 Created,请求体的 JSON 内容如下:

    {"description": "Read this book","status": "Draft","created_by": "user1"
    }
    
  2. 再在该请求下创建一个同名示例 Create Task,其请求方式、URL、状态信息均与上述请求一致,唯独响应体内容不同:

    {"description": "{{ $body 'description' }}","status": "{{ $body 'status' }}"
    }
    

    img12.14

  3. 保存示例,回到 POST 请求,发送请求即可看到如下效果:

    img12.15

重要提示

$body 是 Postman 引用请求体对象的固定写法;访问其中的某个属性要写成 {{ $body 'key_name' }} 的形式,并且为了返回正确的数据类型,括号两边必须加引号,这一点书中是忽略的,很容易出现类型报错。

3.6 模拟 PUT 请求

除了引用请求体的属性值,Postman 还支持对该属性设置默认值。例如,需要响应的 JSON 包含两个字段 descriptionstatus,示例还可以这样设置默认值:

{"description": "{{$body 'description' 'Mock Task {{task_id}}'}}","status": "{{$body 'status' 'Draft'}}"
}

上述代码中,如果请求体的 description 字段有效,则使用该字段值,否则以默认值 "Mock Task {{task_id}}" 进行响应,这里的 {{task_id}} 即上面演示过的路径参数。同理,如果 status 能拿到有效值,则响应时返回对应的 status 属性值,否则按默认值 "Draft" 处理。

实测示例:

img12.16

实测请求1:两个属性值均有效

img12.17

实测请求2:仅 description 有效

img12.18

实测请求3:仅 status 有效

img12.19

注意

经实测,Postman 判定某个字段是否有效的方法,其实就是看该字段是否存在。如果存在,但赋值为 ""null"undefined",都会被视为有效值,如果不符合 JSON 语法规范,则会直接报 400 错误:

图 12.12 违反 JSON 语法规范强行发送请求,Postman 将按 400 报错处理

【图 12.12 违反 JSON 语法规范强行发送请求,Postman 将按 400 报错处理】

3.7 模拟第三方接口返回随机数据

Postman 内置了大量随机变量,以应对各种需要设置随机值的情况,例如城市名称 $randomCity、基于 uuid-v4 的唯一标识字符串 $guid 等,底层参考的是著名的第三方前端随机模块 Faker(详见:https://www.npmjs.com/package/@faker-js/faker)。更多内置变量列表及用法,详见 Postman 官方文档:https://learning.postman.com/docs/tests-and-scripts/write-scripts/variables-list/。

书中给出的示例写法为:

{"country": "US","city": "{{$randomCity}}","language": "en_US","street": "{{$randomStreetAddress}}","Currency": "USD","id": "738964000000291009","state": "New York","first_name": "{{$randomFirstName}}","email": "{{$randomEmail}}","zip": 12345,"created_time": "{{$randomDateRecent}}","last_name": "{{$randomLastName}}","time_zone": "GMT","phone": "{{$randomPhoneNumber}}","dob": "{{$randomDatePast}}","status": "active"
}

可以得到如下结果:

{"country": "US","city": "East Hardyshire","language": "en_US","street": "73801 Isadore Villages","Currency": "USD","id": "738964000000291009","state": "New York","first_name": "Kylie","email": "Piper1@hotmail.com","zip": 12345,"created_time": "Sun Feb 02 2025 20:49:40 GMT+0000 (Coordinated Universal Time)","last_name": "Purdy","time_zone": "GMT","phone": "676-353-0567","dob": "Thu Jan 09 2025 19:30:06 GMT+0000 (Coordinated Universal Time)","status": "active"
}

实测截图:

img12.21

img12.22

注意

Postman 中的内置随机变量还可以用在测试脚本中,通过 pm.variables.replaceIn() 函数进行访问,例如:pm.variables.replaceIn('{{$randomFirstName}}'),实测效果如下:

图 12.13 实测内置随机变量在 Post-response 测试脚本中的用法

【图 12.13 实测内置随机变量在 Post-response 测试脚本中的用法】


由此也可以看出引号的重要作用,千万不可忽略(感觉作者在这个细节上做得很不够,多次出现漏掉引号的情况)。

相关文章:

【玩转 Postman 接口测试与开发2_015】第12章:模拟服务器(Mock servers)在 Postman 中的创建与用法(含完整实测效果图)

《API Testing and Development with Postman》最新第二版封面 文章目录 第十二章 模拟服务器(Mock servers)在 Postman 中的创建与用法1 模拟服务器的概念2 模拟服务器的创建2.1 开启侧边栏2.2 模拟服务器的两种创建方式2.3 私有模拟器的 API 秘钥的用法…...

mysql操作语句与事务

数据库设计范式 数据库设计的三大范式 ‌第一范式(1NF)‌:要求数据库表的每一列都是不可分割的原子数据项,即列中的每个值都应该是单一的、不可分割的实体。例如,如果一个表中的“地址”列包含了省、市、区等多个信息…...

android Camera 的进化

引言 Android 的camera 发展经历了3个阶段 : camera1 -》camera2 -》cameraX。 正文 Camera1 Camera1 的开发中,打开相机,设置参数的过程是同步的,就跟用户实际使用camera的操作步骤一样。但是如果有耗时情况发生时,会…...

ASP.NET Core Filter

目录 什么是Filter? Exception Filter 实现 注意 ActionFilter 注意 案例:自动启用事务的筛选器 事务的使用 TransactionScopeFilter的使用 什么是Filter? 切面编程机制,在ASP.NET Core特定的位置执行我们自定义的代码。…...

Git 的起源与发展

序章:版本控制的前世今生 在软件开发的漫长旅程中,版本控制犹如一位忠诚的伙伴,始终陪伴着开发者们。它的存在,解决了软件开发过程中代码管理的诸多难题,让团队协作更加高效,代码的演进更加有序。 简单来…...

基于SpringBoot电脑组装系统平台系统功能实现五

一、前言介绍: 1.1 项目摘要 随着科技的进步,计算机硬件技术日新月异,包括处理器(CPU)、主板、内存、显卡等关键部件的性能不断提升,为电脑组装提供了更多的选择和可能性。不同的硬件组合可以构建出不同类…...

【智力测试——二分、前缀和、乘法逆元、组合计数】

题目 代码 #include <bits/stdc.h> using namespace std; using ll long long; const int mod 1e9 7; const int N 1e5 10; int r[N], c[N], f[2 * N]; int nr[N], nc[N], nn, nm; int cntr[N], cntc[N]; int n, m, t;void init(int n) {f[0] f[1] 1;for (int i …...

第 1 天:UE5 C++ 开发环境搭建,全流程指南

&#x1f3af; 目标&#xff1a;搭建 Unreal Engine 5&#xff08;UE5&#xff09;C 开发环境&#xff0c;配置 Visual Studio 并成功运行 C 代码&#xff01; 1️⃣ Unreal Engine 5 安装 &#x1f539; 下载与安装 Unreal Engine 5 步骤&#xff1a; 注册并安装 Epic Game…...

axios如何利用promise无痛刷新token

目录 需求 需求解析 实现思路 方法一&#xff1a; 方法二&#xff1a; 两种方法对比 实现 封装axios基本骨架 instance.interceptors.response.use拦截实现 问题和优化 如何防止多次刷新token 同时发起两个或以上的请求时&#xff0c;其他接口如何重试 最后完整代…...

玉米苗和杂草识别分割数据集labelme格式1997张3类别

数据集格式&#xff1a;labelme格式(不包含mask文件&#xff0c;仅仅包含jpg图片和对应的json文件) 图片数量(jpg文件个数)&#xff1a;1997 标注数量(json文件个数)&#xff1a;1997 标注类别数&#xff1a;3 标注类别名称:["corn","weed","Bean…...

【自学笔记】GitHub的重点知识点-持续更新

提示&#xff1a;文章写完后&#xff0c;目录可以自动生成&#xff0c;如何生成可参考右边的帮助文档 文章目录 GitHub使用指南详细知识点一、GitHub基础与账户管理1. GitHub简介2. 创建与管理GitHub账户3. 创建与配置仓库&#xff08;Repository&#xff09; 二、Git基础与Git…...

string例题

一、字符串最后一个单词长度 题目解析&#xff1a;由题输入一段字符串或一句话找最后一个单词的长度&#xff0c;也就是找最后一个空格后的单词长度。1.既然有空格那用我们常规的cin就不行了&#xff0c;我们这里使用getline,2.读取空格既然是最后一个空格后的单词&#xff0c;…...

算法基础——一致性

引入 最早研究一致性的场景既不是大数据领域&#xff0c;也不是分布式系统&#xff0c;而是多路处理器。 可以将多路处理器理解为单机计算机系统内部的分布式场景&#xff0c;它有多个执行单元&#xff0c;每一个执行单元都有自己的存储(缓存)&#xff0c;一个执行单元修改了…...

【数据采集】案例01:基于Scrapy采集豆瓣电影Top250的详细数据

基于Scrapy采集豆瓣电影Top250的详细数据 Scrapy 官方文档:https://docs.scrapy.org/en/latest/豆瓣电影Top250官网:https://movie.douban.com/top250写在前面 实验目的:基于Scrapy框架采集豆瓣电影Top250的详细数据。 电脑系统:Windows 使用软件:PyCharm、Navicat Python…...

设计模式 - 行为模式_Template Method Pattern模板方法模式在数据处理中的应用

文章目录 概述1. 核心思想2. 结构3. 示例代码4. 优点5. 缺点6. 适用场景7. 案例&#xff1a;模板方法模式在数据处理中的应用案例背景UML搭建抽象基类 - 数据处理的 “总指挥”子类定制 - 适配不同供应商供应商 A 的数据处理器供应商 B 的数据处理器 在业务代码中整合运用 8. 总…...

Spring Boot框架下的单元测试

1. 什么是单元测试 1.1 基本定义 单元测试(Unit Test) 是对软件开发中最小可测单位&#xff08;例如一个方法或者一个类&#xff09;进行验证的一种测试方式。在 Java 后端的 Spring Boot 项目中&#xff0c;单元测试通常会借助 JUnit、Mockito 等框架对代码中核心逻辑进行快…...

git中文件的状态状态切换

在 Git 中&#xff0c;文件的状态是指文件相对于 Git 仓库的当前情况。以下是一些常见的文件状态及其含义&#xff1a; 未跟踪&#xff08;Untracked&#xff09;&#xff1a; 这是新创建的文件或从其他位置复制过来的文件&#xff0c;Git 还没有开始跟踪这些文件的更改。 这些…...

基于脉冲响应不变法的IIR滤波器设计与MATLAB实现

一、设计原理 脉冲响应不变法是一种将模拟滤波器转换为数字滤波器的经典方法。其核心思想是通过对模拟滤波器的冲激响应进行等间隔采样来获得数字滤波器的单位脉冲响应。 设计步骤&#xff1a; 确定数字滤波器性能指标 将数字指标转换为等效的模拟滤波器指标 设计对应的模拟…...

RabbitMQ快速上手及入门

概念 概念&#xff1a; publisher&#xff1a;生产者&#xff0c;也就是发送消息的一方 consumer&#xff1a;消费者&#xff0c;也就是消费消息的一方 queue&#xff1a;队列&#xff0c;存储消息。生产者投递的消息会暂存在消息队列中&#xff0c;等待消费者处理 exchang…...

自动化构建-make/Makefile 【Linux基础开发工具】

文章目录 一、背景二、Makefile编译过程三、变量四、变量赋值1、""是最普通的等号2、“:” 表示直接赋值3、“?” 表示如果该变量没有被赋值&#xff0c;4、""和写代码是一样的&#xff0c; 五、预定义变量六、函数**通配符** 七、伪目标 .PHONY八、其他常…...

计算机网络之计算机网络的分类

计算机网络可以根据不同的角度进行分类&#xff0c;以下是几种常见的分类方式&#xff1a; 1. 按照规模和范围&#xff1a; 局域网&#xff08;LAN&#xff0c;Local Area Network&#xff09;&#xff1a;覆盖较小范围&#xff08;例如一个建筑物或校园&#xff09;&#xf…...

MySQl的日期时间加

MySQL日期相关_mysql 日期加减-CSDN博客MySQL日期相关_mysql 日期加减-CSDN博客 raise notice 查询目标 site:% model:% date:% target:%,t_shipment_date.site,t_shipment_date.model,t_shipment_date.plant_date,v_date_shipment_qty_target;...

响应式编程与协程

响应式编程与协程的比较 响应式编程的弊端虚拟线程Java线程内核线程的局限性传统线程池的demo虚拟线程的demo 响应式编程的弊端 前面用了几篇文章介绍了响应式编程&#xff0c;它更多的使用少量线程实现线程间解耦和异步的作用&#xff0c;如线程的Reactor模型&#xff0c;主要…...

智能小区物业管理系统推动数字化转型与提升用户居住体验

内容概要 在当今快速发展的社会中&#xff0c;智能小区物业管理系统的出现正在改变传统的物业管理方式。这种系统不仅仅是一种工具&#xff0c;更是一种推动数字化转型的重要力量。它通过高效的技术手段&#xff0c;将物业管理与用户居住体验紧密结合&#xff0c;无疑为社区带…...

从Proxmox VE开始:安装与配置指南

前言 Proxmox Virtual Environment (Proxmox VE) 是一个开源的虚拟化平台&#xff0c;基于Debian Linux&#xff0c;支持KVM虚拟机和LXC容器。它提供了一个强大的Web管理界面&#xff0c;方便用户管理虚拟机、存储、网络等资源。Proxmox VE广泛应用于企业级虚拟化、云计算和开…...

【Docker项目实战】使用Docker部署MinIO对象存储(详细教程)

【Docker项目实战】使用Docker部署MinIO对象存储 前言一、 MinIO介绍1.1 MinIO简介1.2 主要特点1.3 主要使用场景二、本次实践规划2.1 本地环境规划2.2 本次实践介绍三、本地环境检查3.1 检查Docker服务状态3.2 检查Docker版本3.3 检查docker compose 版本四、下载MinIO镜像五、…...

【C++】B2115 密码翻译

博客主页&#xff1a; [小ᶻ☡꙳ᵃⁱᵍᶜ꙳] 本文专栏: C 文章目录 &#x1f4af;前言&#x1f4af;题目解析&#x1f4af;1. 老师的做法代码实现&#xff1a;思路解析&#xff1a; &#x1f4af;2. 我的做法代码实现&#xff1a;思路分析&#xff1a; &#x1f4af;3. 老师…...

02.04 数据类型

请写出以下几个数据的类型&#xff1a; 整数 a ----->int a的地址 ----->int* 存放a的数组b ----->int[] 存放a的地址的数组c ----->int*[] b的地址 ----->int* c的地址 ----->int** 指向printf函数的指针d ----->int (*)(const char*, ...) …...

Leetcode—598. 区间加法 II【简单】

2025每日刷题&#xff08;206&#xff09; Leetcode—598. 区间加法 II 实现代码 class Solution { public:int maxCount(int m, int n, vector<vector<int>>& ops) {int ans m * n;int x ops.size();if(ops.empty()) {return ans;}int xm ops[0][0], ym …...

AI浪潮下的IT从业者:危机、机遇与进化之路

目录 0. 前言1. 当前形势&#xff1a;站在十字路口1.1 AI的突飞猛进1.2 行业现状分析 2. 核心应对策略2.1 技术深度与广度的平衡2.2 人机协同的工作模式2.3 持续学习与创新 3. 结语 0. 前言 在人工智能快速发展的今天&#xff0c;IT从业者面临前所未有的挑战与机遇。本文将从实…...