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,在引用的地方就是红色无法引用"

相关推荐
卓码软件测评12 小时前
第三方软件测试测评机构【使用web_reg_save_param_ex函数:掌握LoadRunner关联的黄金法则 】
测试工具·ci/cd·性能优化·单元测试·测试用例
快乐小胡!18 小时前
【自动化测试】Selenium选择/定位元素的基本方法
python·selenium·测试工具
PhotonixBay21 小时前
车载HUD的 TFT 屏被动散热仿真与太阳光测试
测试工具
Apifox.1 天前
测试用例越堆越多?用 Apifox 测试套件让自动化回归更易维护
运维·前端·后端·测试工具·单元测试·自动化·测试用例
AI_56781 天前
K8s新手入门:从“Pod创建”到“服务暴露”,3个案例理解容器编排
人工智能·学习·测试工具
我的offer在哪里1 天前
Figma 技术深度解析:重新定义协作设计的底层架构与工程实践
测试工具·流程图
weixin_462446231 天前
在宝塔 Nginx 上安装与配置 lua-cjson 教程
nginx·junit·lua
猿小羽1 天前
[TEST] Selenium 自动化测试 - 1769003387277
selenium·测试工具
猿小羽1 天前
[TEST] Selenium 自动化测试 - 1769003091046
selenium·测试工具
线束线缆组件品替网2 天前
Switchcraft TRS XLR 音频线缆国产兼容设计解析
数码相机·测试工具·电脑·音视频·pcb工艺·智能手表