news 2026/4/3 4:16:35

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/4/2 3:39:28

PyTorch安装教程GPU版多卡配置要点

PyTorch GPU 多卡训练环境搭建与优化实战 在深度学习模型日益庞大的今天,单块 GPU 已经难以支撑百亿参数级模型的训练需求。从 Llama 系列大语言模型到 Stable Diffusion 这类生成式 AI 应用,计算资源的瓶颈正不断推动我们向多卡并行、分布式训练的方向…

作者头像 李华
网站建设 2026/3/8 21:54:25

使用Markdown制作目录提升技术博客可读性

使用Markdown制作目录提升技术博客可读性 在人工智能项目开发中,一个常见的场景是:团队成员拉取了同一个深度学习镜像,却因为文档不清、操作步骤分散而反复询问“怎么启动Jupyter”、“Token在哪看”。这种低效沟通的背后,往往不是…

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

Apache Druid REST API实战操作手册:快速上手实时分析数据库

Apache Druid REST API实战操作手册:快速上手实时分析数据库 【免费下载链接】druid Apache Druid: a high performance real-time analytics database. 项目地址: https://gitcode.com/gh_mirrors/druid6/druid Druid REST API为实时分析数据库提供了强大的…

作者头像 李华
网站建设 2026/3/31 4:31:02

将Transformer模型转换为TensorFlow SavedModel格式

将Transformer模型转换为TensorFlow SavedModel格式 在当今AI系统日益走向工业化的背景下,一个训练好的Transformer模型如果无法高效、稳定地部署到生产环境,其价值将大打折扣。从研究实验室的.py脚本到线上服务的API接口,中间横亘着一条被称…

作者头像 李华
网站建设 2026/4/3 3:20:35

Compose Multiplatform桌面导航:3步解决测试依赖冲突的实战指南

Compose Multiplatform桌面导航:3步解决测试依赖冲突的实战指南 【免费下载链接】compose-multiplatform JetBrains/compose-multiplatform: 是 JetBrains 开发的一个跨平台的 UI 工具库,基于 Kotlin 编写,可以用于开发跨平台的 Android&…

作者头像 李华
网站建设 2026/3/29 17:21:40

ggplot2高效自动化图表生成完整指南

ggplot2高效自动化图表生成完整指南 【免费下载链接】ggplot2 项目地址: https://gitcode.com/gh_mirrors/ggp/ggplot2 想要摆脱重复绘图工作的束缚吗?ggplot2作为R语言中功能最强大的数据可视化工具,其自动化图表生成能力将彻底改变你的工作方式…

作者头像 李华