一、背景
我们在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}}进行引用)
- 比如在浏览器登录你的网站后,去找请求后端接口的请求,找Authorization请求头的值,比如值如果是
-
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拷贝出来分别是 :authority、accept-language、authorization (**Response Headers 一个样拷贝出来小写的)

带冒号的请求头,是http2的一些东西,感兴趣可以去搜
3.3 为什么不建议直接加 authorization header?
为什么不建议把 authorization 到 postman的 Headers,而建议加到 Authorization ? (其他header要加可以在这加)
- 这是 Postman 提供的标准化/智能化方式。
加到Authorization更加方便管理,如前文所述,可以由parent统一管理;你不需要手动输入 Bearer 这个前缀(避免拼写错误或空格遗漏)。切换不同类型的鉴权(如 Basic Auth, AWS Signature)更方便。 - 另外,
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,在引用的地方就是红色无法引用"

