首页
/ Thunder Client 中使用预请求脚本获取令牌的解决方案

Thunder Client 中使用预请求脚本获取令牌的解决方案

2025-06-19 06:53:59作者:秋阔奎Evelyn

问题背景

在使用 Thunder Client 进行 API 测试时,经常会遇到需要先获取一个令牌(token),然后在后续请求中使用这个令牌的情况。这是一个典型的 API 测试场景,特别是在处理认证流程时。

常见错误

许多用户在尝试实现这一流程时会遇到"无法读取未定义的属性'json'"的错误。这通常是由于脚本放置位置不正确或变量引用方式不当导致的。

正确实现方法

第一步:获取令牌的请求

首先创建一个获取令牌的请求,假设端点如下:

{{BASE_URL}}/test/forget

这个请求预期会返回类似以下的JSON响应:

{
  "token": "7c9e63633a28d3d1dd38cac478ec4fb1548e8fd4"
}

第二步:处理响应并存储令牌

在Thunder Client中,正确的做法是将处理响应的脚本放在"Tests"标签页中,而不是"Pre-Run"标签页。脚本内容应为:

var json = tc.response.json;
tc.setVar("token", json.token);

这段代码会:

  1. 从响应中提取JSON数据
  2. 将token值存储到环境变量中

第三步:在后续请求中使用令牌

现在你可以在后续请求中使用这个令牌了,例如:

{{BASE_URL}}/auth/reset/{{token}}

关键注意事项

  1. 脚本位置:确保脚本放在"Tests"标签页,而不是"Pre-Run"标签页
  2. 变量命名:变量名区分大小写,确保引用时与设置时一致
  3. JSON属性:确保引用的JSON属性名与响应中的完全一致

为什么这样做有效

"Tests"标签页中的脚本会在请求完成后执行,因此可以访问到响应数据(tc.response)。而"Pre-Run"脚本在请求发送前执行,此时自然无法访问到响应数据,这就是导致"未定义"错误的原因。

通过这种流程,你可以轻松实现API测试中的令牌获取和使用流程,这对于测试需要认证的API端点特别有用。

登录后查看全文
热门项目推荐
相关项目推荐