news 2026/1/12 1:23:00

Postman接口测试之postman设置接口关联,实现参数化

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
Postman接口测试之postman设置接口关联,实现参数化

🍅点击文末小卡片,免费获取软件测试全套资料,资料在手,涨薪更快

postman设置接口关联

在实际的接口测试中,后一个接口经常需要用到前一个接口返回的结果, 从而让后一个接口能正常执行,这个过程的实现称为关联。

在postman中实现关联操作的步骤如下:

1、利用postman获取上一个接口指定的返回值,可以在tests中提取响应中的字典做全局变量;如下图

2、编写代码设置全局变量,会自动把全局变量的信息加入到Environments中的Globals中,如下图

使用postman全局变量保存上一个接口的值,代码如下:

老版本写法:postman.setGlobalVariable("全局变量名", str); 其中前面的参数为全局变量名称 ,后面为变量

新版本写法:pm.globals.set("token_id", token_value);其中前面的参数为全局变量名称 ,后面为变量

3、和之前引用全局变量一样,使用{{全局变量名}}即可;如下图

postman实现参数化

什么时候会用到参数化

比如:一个模块要用多组不同数据进行测试 == 验证业务的正确性

Login模块:正确的用户名,密码 ===成功;错误的用户名,正确的密码 === 失败

postman实现参数化

在实际的接口测试中,部分参数每次发送请求时都要唯一(比如注册), 这时可采用postman把测试数据进行参数化处理

postman设置参数的形式主要有三种:

  • 内建变量实现
  • Pre-request Script页签中使用代码实现 (推荐)
  • 外部文件的方式实现;如csv文件/json格式文件
一、内建变量实现

Postman有以下三种内建变量,适合一次性使用;缺点:内键变量不能做精确对比

{{$guid}}:生成GUID;如下图:

{{$timestamp}}:当前时间戳;如下图

可通过在线时间戳转换工具查看时间:https://tool.lu/timestamp/

{{$randomInt}}:0-1000的随机整数

二、Pre-request Script页签中使用代码实现(推荐)

Pre-request Script为执行接口请求之前要做的操作,而tests是执行完请求要 做的操作。内建变量一般放在Request里,我们也可以用代码在Pre-request Script中实现,用代码实现的好处是可以复用。

Pre-request Script 与test 一样 支持javascript语法

在Pre-request Script中实现的几种参数化;如下

//获取当前时间戳 毫秒 var now_time = Date.now() pm.globals.set("now_time",now_time) //guid实现 const guid = 'xxxxxxxx-xxxx-4xxx-yxxx-xxxxxxxxxxxx' .replace(/x/g, () => (Math.floor(Math.random() * 16)).toString(16)) .replace(/y/g, () => (Math.floor(Math.random() * 4 + 8)).toString(16)); pm.globals.set("guid_value",guid) //随机整数实现 const randomInt = (min, max) => Math.floor(Math.random() * (max - min + 1)) + min pm.globals.set("randomInt_num",randomInt(8,15)) //从多个选项中选择实现 const randomInt = (min, max) => Math.floor(Math.random() * (max - min + 1)) + min const getRandomValue = list => list[randomInt(0, list.length - 1)]; const charsInName = ['王','李','张'] pm.globals.set("people_name",getRandomValue(charsInName)) //随机手机号实现 const randomInt = (min, max) => Math.floor(Math.random() * (max - min + 1)) + min var mobile_num = `18${randomInt(100000000, 999999999)}`; pm.globals.set("mobile_num",mobile_num) //同步等待实现:等待5秒后开始执行 const sleep = (milliseconds) => { const start = Date.now(); while (Date.now() <= start + milliseconds) {} } sleep(5000)

实战示例:通过Pre-request Script编写代码可以在随机参数中做断言的精确比对

1、在Pre-request Script中编写代码

2、在请求中引用变量;{{变量名}}

3、在tests中做断言,验证实际结果和预期结果是否一致

4、查看执行结果

三、外部文件方式实现参数化

在postman中,除了上述两种方法实现参数化,还可以利用外部数据文件 (支持csv文件和包含json格式文本的数据)。外部数据文件目前是通过Runner 页签可以进行导入。

csv文件格式举例:

csv文件要在Collection Runner中工作,第一行必须是在request中要使用的 变量名,每一行是一条用例,并表示一次迭代。

1、先准备csv文件,编码是UTF-8;如上图

2、在postman中引用变量名,如下图中的百度搜索中wd的参数引入了{{search_word}},tests页签中做断言引用了data.expected_result

3、点击Runner按钮,勾选需执行的请求,在设置循环次数,导入csv文件,点击run执行;如下图

4、查看执行结果

json文件你需要确保你的文件有键/值对数组。数组中的每个元素是键值对对 象,代表一次迭代。key作为request中要使用的变量名,value作为key的取值。

json文件实现参数化步骤:

1、准备要使用的json格式测试数据文件;

2、在postman脚本中,HTTP requests中使用{{ key }}去引用,在script中使用 data. key 或者 data[“key”] 去引用;

3、打开Runner窗口,点击Data旁边的Select File按钮,导入jsondata参数化文件; 点击Data File Type类型选择application/json后,点击Preview按钮,检查数据正确

4、查看执行结果

最后感谢每一个认真阅读我文章的人,礼尚往来总是要有的,虽然不是什么很值钱的东西,如果你用得到的话可以直接拿走:

这些资料,对于做【软件测试】的朋友来说应该是最全面最完整的备战仓库,这个仓库也陪伴我走过了最艰难的路程,希望也能帮助到你!凡事要趁早,特别是技术行业,一定要提升技术功底。

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/1/11 7:51:41

Dify智能体平台集成Qwen3-8B:打造个性化AI工作流

Dify智能体平台集成Qwen3-8B&#xff1a;打造个性化AI工作流 在企业纷纷寻求AI落地的今天&#xff0c;一个现实问题摆在面前&#xff1a;如何在有限预算和算力条件下&#xff0c;构建真正可用、安全可控的智能应用&#xff1f;许多团队曾尝试接入GPT-4等云端大模型&#xff0c;…

作者头像 李华
网站建设 2025/12/15 16:12:38

AutoGPT镜像用户案例:一名自由职业者的工作流变革

AutoGPT镜像用户案例&#xff1a;一名自由职业者的工作流变革 在自由撰稿人的世界里&#xff0c;时间是最稀缺的资源。一个典型的项目周期往往从客户发来一句话需求开始&#xff1a;“写一篇关于AI教育趋势的深度分析。”接下来是漫长的资料搜集、框架搭建、内容撰写与反复修改…

作者头像 李华
网站建设 2025/12/15 16:12:01

分布式锁原理深度解析:从理论到实践

分布式锁原理深度解析&#xff1a;从理论到实践 一、为什么需要分布式锁&#xff1f;—— 先搞懂 “锁” 的场景延伸 在单机应用中&#xff0c;我们用synchronized&#xff08;Java&#xff09;、mutex&#xff08;C&#xff09;等本地锁就能解决多线程并发竞争资源的问题&am…

作者头像 李华
网站建设 2025/12/15 16:11:38

HuggingFace镜像网站加速技巧:快速拉取Qwen3-8B模型权重

HuggingFace镜像网站加速技巧&#xff1a;快速拉取Qwen3-8B模型权重 在大语言模型&#xff08;LLM&#xff09;日益普及的今天&#xff0c;越来越多开发者希望将强大的AI能力集成到本地项目中。然而&#xff0c;一个现实问题摆在眼前&#xff1a;当你兴冲冲地准备下载 Qwen3-8…

作者头像 李华
网站建设 2026/1/4 14:19:44

transformer模型详解之Qwen3-8B架构深度剖析

Qwen3-8B 架构深度剖析&#xff1a;轻量高效背后的工程智慧 在大模型“军备竞赛”愈演愈烈的今天&#xff0c;百亿甚至千亿参数的模型不断刷新着性能上限。然而&#xff0c;对大多数企业和开发者而言&#xff0c;真正困扰他们的从来不是“能不能做出更强的模型”&#xff0c;而…

作者头像 李华
网站建设 2025/12/15 16:08:55

AutoGPT项目依赖项更新策略:保持组件最新

AutoGPT项目依赖项更新策略&#xff1a;保持组件最新 在当今快速迭代的AI时代&#xff0c;一个看似不起眼的技术决策——如何管理开源项目的依赖项&#xff0c;往往决定了整个系统的生死存亡。以AutoGPT为例&#xff0c;这个曾引爆GitHub趋势榜的自主智能体项目&#xff0c;其核…

作者头像 李华