【Postman】无法在脚本中获取本地文件

在Postman中,由于安全限制,预请求脚本无法直接访问本地文件。为解决此问题,可以使用http-server将本地文件映射到URL并从该URL读取。然而,通过这种方式获取的文件进行SHA1编码后,结果与在线工具和Python编码不一致。文章探讨了这一问题及其潜在原因。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

项目场景:

使用Postman模拟发送请求以测试接口,要求postman读取本地文件,并对文件进行签名


问题描述

Pre-request Script中无法获取Body中的文件

...
console.log(request)
...

在这里插入图片描述


原因分析:

这是由于Postman出于安全考虑而将javascript脚本运行在沙盒中,而沙盒无法访问本地文件
参考:
https://www.jianshu.com/p/a75116c9bdb2
https://community.postman.com/t/how-can-i-read-a-json-file-from-within-a-pre-request-script-without-using-the-runner/25835
https://community.postman.com/t/how-to-parse-a-local-json-xml-file-in-a-postman/5520/2


解决方案:

通过在pre-request script中构建请求来获取本地文件即可

首先,使用http-server将本地文件映射到API中

>>> npm install http-server -g
>>> http-server

参考:https://stackoverflow.com/a/16350826

...
pm.sendRequest({
    url: `http://127.0.0.1:8080/Book1.xlsx`,
    method: 'GET',
}, function(err, res) {
    console.log(res.text())
    console.log(CryptoJS.SHA1(res.text()).toString())
});
...

但是问题出现了:将此方式获取的文件进行SHA1编码与在线sha1以及Python sha1编码结果不一致
查了好久没有发现是什么原因,如果你知道,望不吝赐教🙏

### 在 Postman读取本地文件数据的方法 Postman 提供了一种强大的功能,允许用户通过集合运行器(Collection Runner)或监控器(Monitors)来加载和使用本地文件中的数据。以下是具体的操作方法以及实现细节。 --- #### 1. 准备本地文件 首先,准备好要使用的本地文件。常见的文件格式包括 JSON 和 CSV。例如,JSON 文件的内容如下所示: ```json [ { "id": 1, "name": "Alice", "email": "alice@example.com" }, { "id": 2, "name": "Bob", "email": "bob@example.com" } ] ``` CSV 文件则可以是这样的形式: ```csv id,name,email 1,Alice,alice@example.com 2,Bob,bob@example.com ``` --- #### 2. 加载本地文件PostmanPostman 中,无法直接从磁盘读取文件内容,但可以通过以下两种方式间接实现这一目的: ##### 方法一:通过 Collection Runner 导入数据文件 - 打开目标集合(Collection),点击右上角的 `Run` 按钮以启动 Collection Runner。 - 在弹出窗口中找到 **Data** 部分,点击 `Choose Files` 按钮选择准备好的 JSON 或 CSV 文件[^1]。 - 完成文件选择后,Postman 会自动解析文件内容,并将其映射为每次迭代的数据源。 ##### 方法二:手动上传文件并通过脚本处理 如果需要更灵活的方式,也可以通过表单上传接口发送文件,并在请求中读取其内容: - 创建一个新的 POST 请求,设置请求类型为 `form-data`。 - 添加一个键值对,其中 Key 设为 `file`,Value 类型设为 `File`,然后选择本地文件[^3]。 示例代码用于验证上传文件是否成功: ```javascript // 断言文件上传成功 pm.test("断言: 文件上传成功", function () { pm.response.to.have.status(200); }); // 解析返回的响应数据 const responseBody = pm.response.json(); if (responseBody.fileUploaded === true) { pm.environment.set("uploadedFileName", responseBody.fileName); } ``` --- #### 3. 使用数据文件中的字段 无论采用哪种方式加载数据文件,都可以通过 `pm.iterationData.get()` 方法访问对应的字段值。例如: ```javascript // 获取 JSON 文件中的字段值 var id = pm.iterationData.get("id"); var name = pm.iterationData.get("name"); var email = pm.iterationData.get("email"); // 将字段值设置为环境变量 pm.variables.set('userId', id); pm.variables.set('userName', name); pm.variables.set('userEmail', email); console.log(`User ID: ${id}, Name: ${name}, Email: ${email}`); ``` 对于 CSV 文件,同样适用上述语法,只需确保文件结构正确即可。 --- #### 4. 实现断言与自定义逻辑 在实际开发过程中,通常还需要对接口的响应结果进行校验。以下是一些常用的断言模板: - **HTTP 状态码** ```javascript pm.test("断言: HTTP 状态码为 200", function () { pm.response.to.have.status(200); }); ``` - **响应时间** ```javascript pm.test("断言: 响应时间小于 200ms", function () { pm.expect(pm.response.responseTime).to.be.below(200); }); ``` - **自定义字段匹配** ```javascript var expectedName = pm.variables.get("userName"); var actualResponse = pm.response.json(); pm.test("断言: 返回的名字与预期一致", function () { pm.expect(actualResponse.name).to.eql(expectedName); }); ``` --- ### 总结 综上所述,在 Postman读取本地文件数据主要依赖于 Collection Runner 的数据导入功能或通过 API 接口上传文件并解析其内容。无论是哪一种方式,都能满足大多数场景下的需求。 ---
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值