Postman脚本:迭代JSON响应并根据条件动态设置全局变量

Postman脚本:迭代JSON响应并根据条件动态设置全局变量

本教程详细讲解如何在Postman中编写Pre-request或Test脚本,以迭代处理复杂的JSON响应数据。我们将重点介绍如何遍历JSON数组,根据特定布尔条件(如isRetail)动态提取数据(如id),并将其存储到Postman全局变量中。文章将指出常见的循环边界错误和类型比较陷阱,并提供修正后的代码示例及最佳实践,确保脚本的健壮性和准确性。

在api测试自动化中,经常需要从复杂的json响应中提取特定数据。postman提供了强大的脚本能力,允许用户通过javascript处理响应数据。本节将指导您如何遍历一个json数组,并根据数组中元素的特定属性(例如布尔值)来决定是否将其某个字段存储为postman全局变量。

场景描述

假设您从一个API端点获取到以下JSON响应,其中包含一个users数组,每个用户对象都有一个id和一个isRetail布尔属性。您的目标是遍历这个users数组:如果isRetail为true,则将其id存储到名为UserId的全局变量中;如果isRetail为false,则将其id存储到名为orgUserId的全局变量中。

{    "status": 200,    "data": {        "users": [            {                "id": 95,                                "isRetail": true            },            {                "id": 118,                               "isRetail": false            }        ],        "pagination": {            "pageNumber": 1,            "pageSize": 25,            "totalCount": 2,            "totalPages": 1,            "isFirst": true,            "isLast": true,            "totalCountOnPage": 2        }    }}

常见问题及解决方案

在实现上述逻辑时,初学者可能会遇到一些常见的脚本错误,导致代码无法正常运行,例如 TypeError: Cannot read properties of undefined (reading ‘isRetail’)。这通常是由于循环边界条件不正确或数据类型比较不准确造成的。

以下是修正后的Postman测试脚本,它解决了这些常见问题:

// 解析API响应为JSON对象const responseJson = pm.response.json();// 确保响应中存在data.users数组if (responseJson && responseJson.data && Array.isArray(responseJson.data.users)) {    const usersArray = responseJson.data.users;    const usersLength = usersArray.length;    // 遍历users数组    for (let i = 0; i < usersLength; i++) {        const currentUser = usersArray[i]; // 获取当前用户对象        // 确保当前用户对象和isRetail属性存在        if (currentUser && typeof currentUser.isRetail === 'boolean') {            const isRetailUser = currentUser.isRetail;            // 根据isRetail的布尔值设置全局变量            if (isRetailUser === true) {                pm.globals.set("UserId", currentUser.id);                console.log(`设置全局变量 UserId 为: ${currentUser.id}`);            } else if (isRetailUser === false) {                pm.globals.set("orgUserId", currentUser.id);                console.log(`设置全局变量 orgUserId 为: ${currentUser.id}`);            }        } else {            console.warn(`跳过无效的用户对象或isRetail属性在索引 ${i} 处缺失.`);        }    }} else {    console.error("API响应中缺少预期的 'data.users' 数组或其格式不正确.");}

代码解析与关键修正点

循环边界条件修正:for (let i = 0; i < usersLength; i++)

问题: 原始代码中使用 i <= users_len。如果数组长度为 N,其有效索引范围是 0 到 N-1。当 i 达到 users_len 时,尝试访问 usersArray[users_len] 将导致越界,因为该索引不存在,从而返回 undefined。修正: 将循环条件改为 i < usersLength。这确保了循环只迭代到数组的最后一个有效索引 (usersLength – 1),避免了访问 undefined 元素,从而解决了 TypeError。

数据类型精确比较:if (isRetailUser === true) 和 else if (isRetailUser === false)

Find JSON Path Online Find JSON Path Online

Easily find JSON paths within JSON objects using our intuitive Json Path Finder

Find JSON Path Online 30 查看详情 Find JSON Path Online 问题: 原始代码中使用 is_retail == “true” 和 is_retail == “false”。JSON响应中的 isRetail 字段是布尔类型 (true 或 false),而不是字符串。使用 == 运算符进行比较时,JavaScript可能会尝试进行类型转换,这虽然在某些情况下可能“碰巧”工作,但不是最佳实践,且容易出错。修正: 使用严格相等运算符 ===,并直接与布尔值 true 和 false 进行比较。=== 不会进行类型转换,要求值和类型都相同,这使得比较更加准确和可靠。

变量声明规范:使用 const 和 let

改进: 在循环内部,使用 const currentUser = usersArray[i]; 和 const isRetailUser = currentUser.isRetail; 来声明变量。const 用于声明一旦赋值后就不能重新赋值的变量,而 let 用于声明可能需要重新赋值的变量。这有助于提升代码的可读性和维护性,并避免潜在的变量作用域问题。

健壮性增强:空值和类型检查

在访问 responseJson.data.users 之前,增加了 if (responseJson && responseJson.data && Array.isArray(responseJson.data.users)) 检查,确保路径上的每个对象都存在且 users 是一个数组。在处理每个 currentUser 时,增加了 if (currentUser && typeof currentUser.isRetail === ‘boolean’) 检查,确保当前用户对象及其 isRetail 属性存在且类型正确,进一步提高了脚本的健壮性。

注意事项与最佳实践

理解JSON结构: 在编写任何解析JSON的脚本之前,务必仔细检查API响应的JSON结构。Postman的“Pretty”或“Visualize”功能可以帮助您直观地理解数据层级。严格相等运算符 (===): 始终优先使用 === 而不是 == 进行比较,以避免JavaScript的隐式类型转换可能带来的意外行为。数组索引: 记住数组索引总是从 0 开始,到 length – 1 结束。在循环中,常见的错误是使用 i <= length 而不是 i < length。错误处理: 编写脚本时,考虑API响应可能不包含预期数据的情况(例如,data 对象可能缺失,users 数组可能为空或不存在)。添加适当的条件检查可以使您的脚本更加健壮。Postman变量作用域: 熟悉 pm.globals.set()、pm.environment.set() 等函数,了解不同作用域变量的生命周期和用途。调试: 使用 console.log() 在Postman控制台中输出变量值,是调试脚本的有效方法。

通过遵循这些指导原则和最佳实践,您可以在Postman中编写出高效、准确且健壮的脚本,以自动化您的API测试流程。

以上就是Postman脚本:迭代JSON响应并根据条件动态设置全局变量的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/328502.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年11月5日 13:08:01
下一篇 2025年11月5日 13:08:32

相关推荐

  • 怎样用免费工具美化PPT_免费美化PPT的实用方法分享

    利用KIMI智能助手可免费将PPT美化为科技感风格,但需核对文字准确性;2. 天工AI擅长优化内容结构,提升逻辑性,适合高质量内容需求;3. SlidesAI支持语音输入与自动排版,操作便捷,利于紧急场景;4. Prezo提供多种模板,自动生成图文并茂幻灯片,适合学生与初创团队。 如果您有一份内容完…

    2025年12月6日 软件教程
    000
  • Pages怎么协作编辑同一文档 Pages多人实时协作的流程

    首先启用Pages共享功能,点击右上角共享按钮并选择“添加协作者”,设置为可编辑并生成链接;接着复制链接通过邮件或社交软件发送给成员,确保其使用Apple ID登录iCloud后即可加入编辑;也可直接在共享菜单中输入邮箱地址定向邀请,设定编辑权限后发送;最后在共享面板中管理协作者权限,查看实时在线状…

    2025年12月6日 软件教程
    100
  • REDMI K90系列正式发布,售价2599元起!

    10月23日,redmi k90系列正式亮相,推出redmi k90与redmi k90 pro max两款新机。其中,redmi k90搭载骁龙8至尊版处理器、7100mah大电池及100w有线快充等多项旗舰配置,起售价为2599元,官方称其为k系列迄今为止最完整的标准版本。 图源:REDMI红米…

    2025年12月6日 行业动态
    200
  • Linux中如何安装Nginx服务_Linux安装Nginx服务的完整指南

    首先更新系统软件包,然后通过对应包管理器安装Nginx,启动并启用服务,开放防火墙端口,最后验证欢迎页显示以确认安装成功。 在Linux系统中安装Nginx服务是搭建Web服务器的第一步。Nginx以高性能、低资源消耗和良好的并发处理能力著称,广泛用于静态内容服务、反向代理和负载均衡。以下是在主流L…

    2025年12月6日 运维
    000
  • Linux journalctl与systemctl status结合分析

    先看 systemctl status 确认服务状态,再用 journalctl 查看详细日志。例如 nginx 启动失败时,systemctl status 显示 Active: failed,journalctl -u nginx 发现端口 80 被占用,结合两者可快速定位问题根源。 在 Lin…

    2025年12月6日 运维
    100
  • 华为新机发布计划曝光:Pura 90系列或明年4月登场

    近日,有数码博主透露了华为2025年至2026年的新品规划,其中pura 90系列预计在2026年4月发布,有望成为华为新一代影像旗舰。根据路线图,华为将在2025年底至2026年陆续推出mate 80系列、折叠屏新机mate x7系列以及nova 15系列,而pura 90系列则将成为2026年上…

    2025年12月6日 行业动态
    100
  • Linux如何优化系统性能_Linux系统性能优化的实用方法

    优化Linux性能需先监控资源使用,通过top、vmstat等命令分析负载,再调整内核参数如TCP优化与内存交换,结合关闭无用服务、选用合适文件系统与I/O调度器,持续按需调优以提升系统效率。 Linux系统性能优化的核心在于合理配置资源、监控系统状态并及时调整瓶颈环节。通过一系列实用手段,可以显著…

    2025年12月6日 运维
    000
  • 曝小米17 Air正在筹备 超薄机身+2亿像素+eSIM技术?

    近日,手机行业再度掀起超薄机型热潮,三星与苹果已相继推出s25 edge与iphone air等轻薄旗舰,引发市场高度关注。在此趋势下,多家国产厂商被曝正积极布局相关技术,加速抢占这一细分赛道。据业内人士消息,小米的超薄旗舰机型小米17 air已进入筹备阶段。 小米17 Pro 爆料显示,小米正在评…

    2025年12月6日 行业动态
    000
  • 荣耀手表5Pro 10月23日正式开启首销国补优惠价1359.2元起售

    荣耀手表5pro自9月25日开启全渠道预售以来,市场热度持续攀升,上市初期便迎来抢购热潮,一度出现全线售罄、供不应求的局面。10月23日,荣耀手表5pro正式迎来首销,提供蓝牙版与esim版两种选择。其中,蓝牙版本的攀登者(橙色)、开拓者(黑色)和远航者(灰色)首销期间享受国补优惠价,到手价为135…

    2025年12月6日 行业动态
    000
  • Vue.js应用中配置环境变量:灵活管理后端通信地址

    在%ignore_a_1%应用中,灵活配置后端api地址等参数是开发与部署的关键。本文将详细介绍两种主要的环境变量配置方法:推荐使用的`.env`文件,以及通过`cross-env`库在命令行中设置环境变量。通过这些方法,开发者可以轻松实现开发、测试、生产等不同环境下配置的动态切换,提高应用的可维护…

    2025年12月6日 web前端
    000
  • VSCode选择范围提供者实现

    Selection Range Provider是VSCode中用于实现层级化代码选择的API,通过注册provideSelectionRanges方法,按光标位置从内到外逐层扩展选择范围,如从变量名扩展至函数体;需结合AST解析构建准确的SelectionRange链式结构以提升选择智能性。 在 …

    2025年12月6日 开发工具
    000
  • JavaScript动态生成日历式水平日期布局的优化实践

    本教程将指导如何使用javascript高效、正确地动态生成html表格中的日历式水平日期布局。重点解决直接操作`innerhtml`时遇到的标签闭合问题,通过数组构建html字符串来避免浏览器解析错误,并利用事件委托机制优化动态生成元素的事件处理,确保生成结构清晰、功能完善的日期展示。 在前端开发…

    2025年12月6日 web前端
    000
  • JavaScript响应式编程与Observable

    Observable是响应式编程中处理异步数据流的核心概念,它允许随时间推移发出多个值,支持订阅、操作符链式调用及统一错误处理,广泛应用于事件监听、状态管理和复杂异步逻辑,提升代码可维护性与可读性。 响应式编程是一种面向数据流和变化传播的编程范式。在前端开发中,尤其面对复杂的用户交互和异步操作时,J…

    2025年12月6日 web前端
    000
  • JavaScript生成器与迭代器协议实现

    生成器和迭代器基于统一协议实现惰性求值与数据遍历,通过next()方法返回{value, done}对象,生成器函数简化了迭代器创建过程,提升处理大数据序列的效率与代码可读性。 JavaScript中的生成器(Generator)和迭代器(Iterator)是处理数据序列的重要机制,尤其在处理惰性求…

    2025年12月6日 web前端
    000
  • 环境搭建docker环境下如何快速部署mysql集群

    使用Docker Compose部署MySQL主从集群,通过配置文件设置server-id和binlog,编写docker-compose.yml定义主从服务并组网,启动后创建复制用户并配置主从连接,最后验证数据同步是否正常。 在Docker环境下快速部署MySQL集群,关键在于合理使用Docker…

    2025年12月6日 数据库
    000
  • Xbox删忍龙美女角色 斯宾塞致敬板垣伴信被喷太虚伪

    近日,海外游戏推主@HaileyEira公开发表言论,批评Xbox负责人菲尔·斯宾塞不配向已故的《死或生》与《忍者龙剑传》系列之父板垣伴信致敬。她指出,Xbox并未真正尊重这位传奇制作人的创作遗产,反而在宣传相关作品时对内容进行了审查和删减。 所涉游戏为年初推出的《忍者龙剑传2:黑之章》,该作采用虚…

    2025年12月6日 游戏教程
    000
  • 如何在mysql中分析索引未命中问题

    答案是通过EXPLAIN分析执行计划,检查索引使用情况,优化WHERE条件写法,避免索引失效,结合慢查询日志定位问题SQL,并根据查询模式合理设计索引。 当 MySQL 查询性能下降,很可能是索引未命中导致的。要分析这类问题,核心是理解查询执行计划、检查索引设计是否合理,并结合实际数据访问模式进行优…

    2025年12月6日 数据库
    000
  • VSCode入门:基础配置与插件推荐

    刚用VSCode,别急着装一堆东西。先把基础设好,再按需求加插件,效率高还不卡。核心就三步:界面顺手、主题舒服、功能够用。 设置中文和常用界面 打开软件,左边活动栏有五个图标,点最下面那个“扩展”。搜索“Chinese”,装上官方出的“Chinese (Simplified) Language Pa…

    2025年12月6日 开发工具
    000
  • VSCode性能分析与瓶颈诊断技术

    首先通过资源监控定位异常进程,再利用开发者工具分析性能瓶颈,结合禁用扩展、优化语言服务器配置及项目设置,可有效解决VSCode卡顿问题。 VSCode作为主流的代码编辑器,虽然轻量高效,但在处理大型项目或配置复杂扩展时可能出现卡顿、响应延迟等问题。要解决这些性能问题,需要系统性地进行性能分析与瓶颈诊…

    2025年12月6日 开发工具
    000
  • php查询代码怎么写_php数据库查询语句编写技巧与实例

    在PHP中进行数据库查询,最常用的方式是使用MySQLi或PDO扩展连接MySQL数据库。下面介绍基本的查询代码写法、编写技巧以及实用示例,帮助你高效安全地操作数据库。 1. 使用MySQLi进行查询(面向对象方式) 这是较为推荐的方式,适合大多数中小型项目。 // 创建连接$host = ‘loc…

    2025年12月6日 后端开发
    000

发表回复

登录后才能评论
关注微信