软件信创测试和软件首版次认定机构【使用Postman的Pre-request Script动态处理数据】

Postman的Pre-request Script是在HTTP请求发送前执行的JavaScript代码,作用是,能让你动态地准备或修改请求数据,从而模拟真实多变的客户端行为。

常见的动态数据处理情形:

设置动态变量:为请求参数、头部、体部动态生成值,pm.variables.set("timestamp", Date.now());

处理业务:计算签名、拼接加密参数、读取外部数据等,使用 CryptoJS 库计算 HMAC 或 MD5 签名。

控制请求参数:根据思路动态添加或修改请求的 URL、Headers 或 Body,pm.request.headers.add({key: "X-Custom", value: "Dynamic"});

关联前置数据:从前一个请求的响应中提取数据,用于当前请求,一般在 Tests 脚本中提取并设为变量,然后在后续请求的 Pre-request Script 中引用。

生成随机数据:避免重复提交,模拟多样化用户输入,let randomName = 'user' + Math.random().toString(36).substr(2, 5);

数据驱动:从外部CSV/JSON文件读取数据,实现参数化批量测试,在 Collection Runner 中关联数据文件,在脚本中使用 pm.iterationData.get("字段名")。

文章来源:卓码软件测评

精彩推荐:点击蓝字即可
软件负载测试API自动化测试软件测试第三方软件测试软件性能测试软件测试机构

具体应用

下面通过几个具体例子,展示怎样将这些应用到实际中。

1. 处理时间戳和动态签名

对于需要证实签名或时效性的API,可以自动生成并注入动态值。

javascript 复制代码
// 1. 生成13位毫秒级时间戳

const timestamp = Date.now();

pm.variables.set("timestamp", timestamp);



// 2. 假设需要计算签名(使用CryptoJS库,Postman内置支持)

const secret = pm.variables.get("api_secret"); // 从变量中读取密钥

const stringToSign = `param1value${timestamp}${secret}`;

const signature = CryptoJS.MD5(stringToSign).toString(); // 示例用MD5,可选SHA256等

pm.variables.set("signature", signature);



// 3. 在请求URL或Header中,使用 {{timestamp}} 和 {{signature}} 引用变量。

2. 读取并关联外部数据

在数据驱动测试中,可以读取外部文件的数据来填充请求。

javascript 复制代码
// 从数据文件中读取当前迭代的数据(需在Collection Runner中上传CSV/JSON)

const username = pm.iterationData.get("username"); // 对应CSV列名或JSON键

const departmentId = pm.iterationData.get("dept_id");



// 设置到变量中,方便在请求体或URL中引用

pm.variables.set("currentUser", username);

pm.variables.set("currentDeptId", departmentId);



// 也可以在脚本中直接构造或处理数据

const userEmail = `${username}@zmtests.com`;

pm.variables.set("email", userEmail);

3. 模拟随机或规则性用户输入

测试创建接口时,避免因数据重复导致失败。

javascript 复制代码
// 生成随机6位字母数字组合的字符串作为用户名

function generateRandomString(length) {

    return Math.random().toString(36).substr(2, length);

}

pm.variables.set("random_username", "user_" + generateRandomString(6));



// 生成随机手机号

const randomMobilePrefix = ['130', '139', '188'];

const prefix = randomMobilePrefix[Math.floor(Math.random() * randomMobilePrefix.length)];

const suffix = Math.floor(10000000 + Math.random() * 90000000);

pm.variables.set("random_mobile", prefix + suffix);

数据驱动测试流程

Pre-request Script 是数据驱动测试的重点步骤。一个典型的工作流程如下:

准备数据文件:创建 CSV 或 JSON 文件,如 users.csv,包含 username, password, email 等列。

编写脚本:在请求的 Pre-request Script 中,使用 pm.iterationData.get() 读取数据,并可能通过 pm.variables.set() 存入变量。

参数化请求:在请求的URL、Body(如raw JSON)或Headers中,使用 {{变量名}} 引用这些数据。

配置并运行:

在Postman中打开Collection Runner。

选择你的集合(Collection),在 Data标签页上传你的CSV/JSON 文件。

设置迭代次数(一般和数据行数一致),点击运行。Postman会为数据文件的每一行执行一次请求,并自动替换变量。

调试技巧

为了保证脚本按预期工作,可以:

使用 console.log():在脚本中打印变量值,然后在 Postman 的 Console (View → Show Postman Console 或 Ctrl+Alt+C) 中查看输出,这是最直接的调试方式。

执行顺序:脚本执行按照从外到内的顺序:Collection 级 Pre-request Script → Folder 级 → Request 级,然后是发送请求,最后执行对应层级的 Tests 脚本。

使用内置动态变量:Postman 提供了一些开箱即用的动态变量,可在请求中直接使用,如 {{timestamp}}(当前时间戳)、{{randomInt}}(随机整数)、{{$guid}}(GUID)。它们有时能简化脚本。

变量作用域:pm.variables.set() 设置的变量在当前请求及其后的请求中可用(取决于环境)。使用 pm.environment.set() 或 pm.collectionVariables.set() 可以将变量持久化到环境或集合中,供整个工作流使用。

怎样选择应用场景

需要对每个请求进行动态预处理(如计算签名):直接在单个请求的 Pre-request Script 中编写。

需要对集合中所有请求统一执行初始化(如获取全局Token):在集合(Collection) 的 Pre-request Script 中编写。

需要模拟大量不同数据的测试用例(如用户注册):采用数据驱动测试,结合外部数据文件和Collection Runner。

掌握Pre-request Script后,API测试将变得非常动态和强大。

相关推荐
weixin_419658315 小时前
UISpy:Windows 界面控件的“显微镜“[特殊字符]
windows·python·测试工具·ui
网安CILLE6 小时前
Wireshark 抓包实战演示
linux·网络·python·测试工具·web安全·网络安全·wireshark
汽车仪器仪表相关领域6 小时前
双组分精准快检,汽修年检利器:MEXA-324M汽车尾气测量仪项目实战全解
大数据·人工智能·功能测试·测试工具·算法·机器学习·压力测试
月明长歌8 小时前
测试用例篇:从“万能公式”到六大方法,搭一套可复用的用例设计体系
测试用例
handsome09168 小时前
最简单的CI/CD部署流水线用什么工具
ci/cd
June bug8 小时前
【实习笔记】正交实验法设计测试用例
笔记·学习·测试用例
深兰科技8 小时前
俄罗斯T1集团代表团到访深兰科技,就具身智能与复杂场景工程化应用达成多项合作共识
windows·ci/cd·github·visual studio·具身智能·深兰科技·俄罗斯t1集团
天才测试猿9 小时前
Chrome浏览器+Postman做接口测试
自动化测试·软件测试·python·测试工具·测试用例·接口测试·postman
汽车仪器仪表相关领域9 小时前
全组分精准捕获,台架研发中枢:MEXA-ONE发动机尾气测量装置项目实战全景
大数据·人工智能·功能测试·单元测试·压力测试·可用性测试