postman如何设置鉴权authorization header(怎么只设置一次,统一管理,不要每个request重复设置)

一、背景

我们在postman里头建请求(request)之前一般会建集合(collection),用collection来组织多个request。一个postman里头可以建多个collection。

我希望,在collection下面的所有request都能共享 "鉴权" 配置,我不希望每个request里头都单独配置,这样重复的工作很多。

二、实现

其实,每次新建的request,其Authorization都默认继承parent,即 "Inherit auth from parent",那么这个 "parent" 指的是什么?指的就是collection的配置,collection配置了鉴权,下面的所有request都能自动继承配置,即无需在每个request里重复配置。下图是某个request的Authorization默认继承parent

怎么在collection中定义鉴权呢?

如下图步骤,按照自己的实际情况选择鉴权的类型,比如Bearer这种就非常常见,在Token里头填入token的值

  • token要填什么值?从哪里获取?

    • 比如在浏览器登录你的网站后,去找请求后端接口的请求,找Authorization请求头的值,比如值如果是 Bearer xxxx,就去掉 Bearer 前缀,只把 xxxx 填入到下图的Token输入框中
    • 如果有获取token的接口,直接在postman中建一个这样的request,发起请求后将得到的token值,手工复制到下图的Token输入框中(当然,你可以设置token值为环境变量或全局变量,然后下图中填入{{your_access_token_name}}进行引用)
  • postman中的 Authorization的原理,会自动帮你添加 Authorization 请求头,所以你无需再在你的request中的Headers的tab中重复添加。如果重复添加,一般会被collection中设置的值覆盖,这种情况很难察觉,从而很难排查 "为什么填入了正确的token但是不work"

    你可以发起request,从postman的console里头查看请求头,检查传的authorization的值是否是预期的

三、其他补充

3.1 其他补充1

获取token的request,postman的 Tests 这个tab 里头,可以写获取到返回值后的处理逻辑,如图是把返回值(request body)转为json后取里头名为 access_token 的字段的值,并写入到 "环境" 或者 "全局" 中,变量名为 access_token,使用的地方使用 {{access_token}} 即可引用

  • pm.environment... 这是写入到某个环境里头,见下图,由于右上角是 "No Environment", 所以这个写法无法绑定到任何一个环境,会导致使用 {{access_token}} 取值为空
  • pm.globals... 这种是设置到全局scope的,很方便你不想建Environment的时候这么做简单粗暴

如何查看当前环境变量的值?

点击右上角的 "眼睛" 图标

3.2 其他补充2

众所周知,请求头(无论请求头还是响应头)是不区分大小写的,你看本文时有可能会混着说,比如说header是authorization或者Authorization

事实上,chrome的dev tools,给你显示的是大写,但是拷贝出来是小写,不信你去试下

下面的header拷贝出来分别是 :authorityaccept-languageauthorization (**Response Headers 一个样拷贝出来小写的)

带冒号的请求头,是http2的一些东西,感兴趣可以去搜

3.3 为什么不建议直接加 authorization header?

为什么不建议把 authorization 到 postman的 Headers,而建议加到 Authorization ? (其他header要加可以在这加

  1. 这是 Postman 提供的标准化/智能化方式。
    加到Authorization更加方便管理,如前文所述,可以由parent统一管理;你不需要手动输入 Bearer 这个前缀(避免拼写错误或空格遗漏)。切换不同类型的鉴权(如 Basic Auth, AWS Signature)更方便。
  2. 另外,Authorization 里的优先级更高,会覆盖你在Headers加的authorization 请求头

3.4 再补充个 "没用的" 小知识

是不是我们不在 Headers 里填写header在发起请求的时候就没有header呢,不是的,首先,下图提示了有9个隐藏的header,是自动添加的

其次,具体发了什么请求头,还是得看console,这是排查问题的终极利器!! 可以看到确实是9个header

3.5 postman中的变量引用的颜色

前面我们提到,可以使用 {{your_var_name}} 来引用设置到enviroment或者globals,假设你引用的变量是 "可行的",那么是橙色,否则是 "红色"。比如access_token2不存在,所以就是红色。这种情况同样是会出现在 "把变量设置到 pm.environment...但是自己并未定义Enviorment,在引用的地方就是红色无法引用"

相关推荐
2501_924064114 小时前
2025年主流Web自动化测试工具功能与适用场景对比
前端·测试工具·自动化
芒果树技术1 天前
MangoTree案例分享:基于AtomRIO FPGA平台,客户实现自适应主动减振
测试工具·fpga开发·模块测试
程序员三藏1 天前
白盒测试和黑盒测试详解
自动化测试·软件测试·python·功能测试·测试工具·职场和发展·测试用例
代码游侠1 天前
应用——基于C语言实现的简易Web服务器开发
运维·服务器·c语言·开发语言·笔记·测试工具
Wang's Blog1 天前
Lua: 事件处理深度解析之从协程到跨平台架构实践
junit·架构·lua
程序员三藏1 天前
自动化测试与功能测试详解
自动化测试·软件测试·python·功能测试·测试工具·职场和发展·测试用例
浩子智控1 天前
高可靠电子产品软件工程化
测试工具·架构·系统安全·软件工程·敏捷流程
南汐以墨1 天前
UI自动化测试指南(一):浅解概念
java·测试工具
南汐以墨1 天前
UI自动化测试指南(二):常用方法
java·测试工具