news 2026/5/23 7:03:25

PostMan加载三方JS

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
PostMan加载三方JS

PostMan加载三方JS

1. 背景

在Postman中做接口测试时,需要使用第三方js包或者自己封装的js工具处理接口参数.此时需要在执行脚本前加载外部js文件
,并且注入运行环境.目前动态执行js文件,可以使用eval或者使用 new Function()方式加载.这里优先考虑第二种方式.
以下介绍四种方法

  • 通过集合参数或者环境变量添加
  • 通过请求响应添加
  • 直接在脚本中添加
  • 通过pm.require添加npm包

动态添加的脚本如果不能访问注入的对象,可以在调用前添加this.xxx试下.

以下测试代码,均在Pre-request Script页签中执行

测试方式为在在Postman中添加一个GET请求

请求地址为https://www.小游戏.地心侠士.com

虽然地址不存在,但是依然可以测试脚本加载情况.

2. 通过参数添加

/* by yours.tools - online tools website : yours.tools/zh/generateethwallets.html */ (function(){ var script = pm.collectionVariables.get("dayjs_code"); (new Function(script))(); console.log("加载dayjs后,获取当前时间: "+ dayjs().format('YYYY-MM-DD HH:mm:ss SSS')) })()

在左下角的Console面板中输出的内容如下:

/* by yours.tools - online tools website : yours.tools/zh/generateethwallets.html */ 加载dayjs后,获取当前时间: 2025-12-30 19:14:14 949 GET https://www.小游戏.地心侠士.com

3. 通过网络添加

pm.sendRequest("https://cdn.bootcdn.net/ajax/libs/dayjs/1.11.18/dayjs.min.js",(error,resp)=>{ let script = resp.text(); (new Function(script))() console.log("加载dayjs后,获取当前时间: "+ dayjs().format('YYYY-MM-DD HH:mm:ss SSS')) })

在左下角的Console面板中输出的内容如下:

GET https://cdn.bootcdn.net/ajax/libs/dayjs/1.11.18/dayjs.min.js 加载dayjs后,获取当前时间: 2025-12-30 19:05:09 506 GET https://www.小游戏.地心侠士.com

4. 使用eval方式加载

以上的示列,都是是通过Function()方式加载.使用eval方式,参考如下

(function(){ var script = pm.collectionVariables.get("dayjs_code"); eval(script) console.log("使用eval初始脚本,获取当前时间: "+ dayjs().format('YYYY-MM-DD HH:mm:ss SSS')) })()

在左下角的Console面板中输出的内容如下:

使用eval初始脚本,获取当前时间: 2025-12-31 09:26:56 460 GET https://www.小游戏.地心侠士.com

5. 直接复制到脚本中

直接下载dayjs.min.js文件,复制到Pre-request Script内容区域.然后再写具体测试脚本

这里需要注意的是,在调用是需要使用this.dayjs(),不能直接使用dayjs(),可能和postman执行环境没有window对象有关

console.log("加载dayjs后,获取当前时间: "+this.dayjs().format('YYYY-MM-DD HH:mm:ss SSS'))

在左下角的Console面板中输出的内容如下:

加载dayjs后,获取当前时间: 2025-12-30 19:21:46 064 GET https://www.小游戏.地心侠士.com

6. 使用pm.require添加npm包

在高级版本中,或者直接在官网云环境可以是使用

const dayjs = pm.require('npm:dayjs@1.11.19'); console.log("加载dayjs后,获取当前时间: "+ dayjs().format('YYYY-MM-DD HH:mm:ss SSS'))

在左下角的Console面板中输出的内容如下:

加载dayjs后,获取当前时间: 2025-12-30 19:33:07 825 GET https://www.小游戏.地心侠士.com

7. 总结及扩展

总之,在postman的沙箱环境中,加载三方JS主要是两个路径

  • 中JS动态执行能力,使用eval(scriptContent)new Function(scriptContent)
  • 使用Postman内置的包管理能力pm.require('npm:dayjs@1.11.19');可能会有版本要求

内置Web Crypto objects对象,比如CryptoCryptoKeySubtleCryptocrypto property

比如,在Postman脚本中,需要实现AES加密代码如下:

var ciphertext = CryptoJS.AES.encrypt('小游戏地心侠士', '微信').toString(); console.log("AES加密内容 "+ ciphertext)

在左下角的Console面板中输出的内容如下:

AES加密内容 U2FsdGVkX1/N/cvcwUkO1F+V66VM/XFfkBnAJUPk20TpE5Db2+H+lSa2xOx1yAeI GET https://www.小游戏.地心侠士.com

PostMan内置对象参考地址如下:
https://www.cnblogs.com/yfrs/p/19425003/postman_inner_object

原文地址:https://mp.weixin.qq.com/s/EO5lJEskAWGq1DotIVx6Ig

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

深度解构:MyBatis数据源架构设计的哲学思想与实战优化

深度解构:MyBatis数据源架构设计的哲学思想与实战优化 【免费下载链接】mybatis mybatis源码中文注释 项目地址: https://gitcode.com/gh_mirrors/my/mybatis 在当今企业级应用开发中,数据库连接管理是影响系统性能的关键因素之一。MyBatis作为一…

作者头像 李华
网站建设 2026/5/14 18:41:41

为什么说tRPC-Go是微服务开发者的终极选择?

为什么说tRPC-Go是微服务开发者的终极选择? 【免费下载链接】trpc-go A pluggable, high-performance RPC framework written in golang 项目地址: https://gitcode.com/gh_mirrors/tr/trpc-go 在当今云原生时代,高性能RPC框架已成为构建可扩展微…

作者头像 李华
网站建设 2026/5/22 3:33:24

戴森球计划工厂蓝图优化实战:5个维度全面提升生产效率

戴森球计划工厂蓝图优化实战:5个维度全面提升生产效率 【免费下载链接】FactoryBluePrints 游戏戴森球计划的**工厂**蓝图仓库 项目地址: https://gitcode.com/GitHub_Trending/fa/FactoryBluePrints FactoryBluePrints是《戴森球计划》玩家社群精心打造的工…

作者头像 李华
网站建设 2026/5/23 5:28:01

Excel库存管理系统 - 智能仓库管理解决方案

还在为繁琐的库存管理而烦恼吗?每天面对堆积如山的出入库单据、混乱的库存数据,是不是让你感到力不从心?传统的手工记账方式不仅效率低下,还容易出错,严重影响企业的运营效率。 【免费下载链接】Excel库存管理系统-最好…

作者头像 李华
网站建设 2026/5/23 13:25:59

跨端数据存储革命:Taro生态下的SQLite与IndexedDB融合方案

跨端数据存储革命:Taro生态下的SQLite与IndexedDB融合方案 【免费下载链接】taro 开放式跨端跨框架解决方案,支持使用 React/Vue/Nerv 等框架来开发微信/京东/百度/支付宝/字节跳动/ QQ 小程序/H5/React Native 等应用。 https://taro.zone/ 项目地址:…

作者头像 李华