双鸭山市网站建设_网站建设公司_数据备份_seo优化
2026/1/19 10:36:33 网站建设 项目流程

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,可以自动生成并注入动态值。

// 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. 读取并关联外部数据

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

// 从数据文件中读取当前迭代的数据(需在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. 模拟随机或规则性用户输入

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

// 生成随机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测试将变得非常动态和强大。

需要专业的网站建设服务?

联系我们获取免费的网站建设咨询和方案报价,让我们帮助您实现业务目标

立即咨询