Postman 自动获取token 保姆级教程

本文详细介绍了如何在Postman中配置登录流程,包括检查token有效性、创建接口、添加环境变量、预请求脚本设置以及自定义Tests以处理token失效时的自动登录。通过OAuth2.0或Bearertoken,实现接口请求的权限管理。
摘要由CSDN通过智能技术生成

需求功能基本分析

1 项目中使用自定义的登录token来验证是否已登录。
2 如果token失效 需要先调用login接口 然后把token复制到功能接口中才能正常访问 --解决这个痛点
3 OAuth2.0/1.0 和bearer token可以直接使用postman自带的Authorization来配置

登录流程

1 验证header中token是否有效 有则成功 否则返回请登录
2 登录接口 接收账号密码 返回正确token

我们需要postman做的就是这一步 当token失效的时候 自动帮我们调用登录接口 然后把返回的token插入到{当前接口/部分接口/所有接口}
然后再点击发送请求的时候 就使用了新的token访问**

在这里插入图片描述

在postman中创建接口

开始新建我们需要的集合和文件夹
在这里插入图片描述

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
我们可以尝试请求一下接口 看返回什么提示
这步骤很重要 不能忽略 作用是确定接口是畅通的
在这里插入图片描述
确定自己项目的未登录提示语和code码

添加环境变量

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

在这里插入图片描述

配置Pre-request Script

假设我们模块A下的所有请求都需要token 则在模块A里面设置
如果在项目A里面设置 则所有folder下的所有请求都会运行这个前置脚本 看你们需要安排设置在哪里
在这里插入图片描述

//从环境变量中取出loginToken
var loginToken = pm.environment.get("loginToken")
console.log("本次token is "+loginToken)
//设置请求头 前面是header的value 后面是key
pm.request.headers.add(loginToken, "loginToken")

设置Tests

在这里插入图片描述

var data = JSON.parse(responseBody);
//这里根据自己项目返回值判断是否是登录失效
console.log(data)
//一定要根据自己项目的情况来判断
if(data.code == "998"){
    console.log("token失效 调用login接口")
    const url = pm.environment.replaceIn("{{loginUrl}}");
    // 请求登录接口
    const postRequest = {
  url: url,
  method: 'POST',
  // 按照项目登录接口配置
  header: {
   'Content-Type': 'application/json',
  },
  body: {
    mode: 'raw',
    raw: JSON.stringify({ 
        username: '你们的username',
        password: '你们的password'})
  }
};
//请求接口获取token并赋值换环境变量
pm.sendRequest(postRequest, (error, response) => {
	//loginToken是我项目的字段名,按照自己项目接口字段写
    console.log(response.json().token)
    //把接口返回的token设入环境变量中
    pm.environment.set('loginToken', response.json().token);
});
}

小试牛刀

在这里插入图片描述
开始调用
在这里插入图片描述
可以随时查看环境变量
在这里插入图片描述
再次发送请求 顺利获得数据
在这里插入图片描述
至此结束
转眼间和你未见 便寂寞一千三十四天

  • 13
    点赞
  • 45
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值