请求时token过期自动刷新token操作


Posted in Javascript onSeptember 11, 2020

1.在开发过程中,我们都会接触到token,token的作用是什么呢?主要的作用就是为了安全,用户登陆时,服务器会随机生成一个有时效性的token,用户的每一次请求都需要携带上token,证明其请求的合法性,服务器会验证token,只有通过验证才会返回请求结果。

2.当token失效时,现在的网站一般会做两种处理,一种是跳转到登陆页面让用户重新登陆获取新的token,另外一种就是当检测到请求失效时,网站自动去请求新的token,第二种方式在app保持登陆状态上面用得比较多。

3.下面进入主题,我们请求用的是axios,不管用何种请求方式,刷新token的原理都是一样的。

//封装了一个统一的请求函数,这个不是重点

export default function request(url, options) {
  const token = localStorage.getItem('token');
  const defaultOptions = {
    headers: {
      Authorization: `Bearer ${token}`,
    },
    withCredentials: true,
    url: url,
    baseURL: BASE_URL,
  };
  const newOptions = { ...options, ...defaultOptions };
  return axios.request(newOptions)
    .then(checkStatus)
    .catch(error => console.log(error));
}

// 封装了一个检测返回结果的函数,与后台返回状态码code === 1002表示token失效

let isRefreshing = true;
function checkStatus(response) {
 if (response && response.code === 1002) {
  // 刷新token的函数,这需要添加一个开关,防止重复请求
  if(isRefreshing){
    refreshTokenRequst()
  }
  isRefreshing = false;
  // 这个Promise函数很关键
   const retryOriginalRequest = new Promise((resolve) => {
        addSubscriber(()=> {
          resolve(request(url, options))
        })
      });
      return retryOriginalRequest;
 }else{
   return response;
 }
}

// 刷新token的请求函数

function refreshTokenRequst(){
  let data;
  const refreshToken = localStorage.getItem('refreshToken');
  data:{
    authorization: 'YXBwYXBpczpaSWxhQUVJdsferTeweERmR1praHk=',
    refreshToken,
  }
  axios.request({
    baseURL: BASE_URL,
    url:'/app/renewal',
    method: 'POST',
    data,
  }).then((response)=>{
    localStorage.setItem('refreshToken',response.data.refreshToken);
    localStorage.setItem('token',response.data.token);
    onAccessTokenFetched();
    isRefreshing = true;
  });
}

// Promise函数集合

let subscribers = [];
function onAccessTokenFetched() {
  subscribers.forEach((callback)=>{
    callback();
  })
  subscribers = [];
}

function addSubscriber(callback) {
  subscribers.push(callback)
}

总结:

其实token失效,自动刷新token,在页面只有一个请求的时候是比较好处理的,但是如果页面同时有多个请求,并且都会产生token失效,这就需要一些稍微复杂的处理,解决方式主要是用了Promise 函数来进行处理。

每一个token失效的请求都会存到一个Promise函数集合里面,当刷新token的函数执行完毕后,才会批量执行这些Promise函数,返回请求结果。

还有一点要注意一下,这儿设置一个刷新token的开关isRefreshing,这个是非常有必要的,防止重复请求。

以上这篇请求时token过期自动刷新token操作就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
基于jQuery的前端数据通用验证库
Aug 08 Javascript
JavaScript制作淘宝星级评分效果的思路
Jun 23 Javascript
Spring MVC中Ajax实现二级联动的简单实例
Jul 06 Javascript
Node.JS文件系统解析实例详解
May 15 Javascript
ES6入门教程之Iterator与for...of循环详解
May 17 Javascript
基于vue+ bootstrap实现图片上传图片展示功能
May 17 Javascript
AngularJs 延时器、计时器实例代码
Sep 16 Javascript
layer子层给父层页面元素赋值,以达到向父层页面传值的效果实例
Sep 22 Javascript
jquery实现左右轮播图效果
Sep 28 jQuery
利用jquery如何从json中读取数据追加到html中
Dec 01 jQuery
基于JS实现web端录音与播放功能
Apr 17 Javascript
three.js利用gpu选取物体并计算交点位置的方法示例
Nov 25 Javascript
vue+axios 拦截器实现统一token的案例
Sep 11 #Javascript
Vue axios获取token临时令牌封装案例
Sep 11 #Javascript
Vue-cli4 配置 element-ui 按需引入操作
Sep 11 #Javascript
vue 子组件和父组件传值的示例
Sep 11 #Javascript
jQuery实现朋友圈查看图片
Sep 11 #jQuery
详解webpack的文件监听实现(热更新)
Sep 11 #Javascript
js代码编写无缝轮播图
Sep 13 #Javascript
You might like
PHP+DBM的同学录程序(3)
2006/10/09 PHP
php sprintf()函数让你的sql操作更安全
2008/07/23 PHP
smarty模板嵌套之include与fetch性能测试
2010/12/05 PHP
PHP将整个网站生成HTML纯静态网页的方法总结
2012/02/05 PHP
PHP+MySQL修改记录的方法
2015/01/21 PHP
Laravel模板引擎Blade中section的一些标签的区别介绍
2015/02/10 PHP
PHP的Yii框架入门使用教程
2016/02/15 PHP
php实现登陆模块功能示例
2016/10/20 PHP
针对thinkPHP5框架存储过程bug重写的存储过程扩展类完整实例
2018/06/16 PHP
Laravel框架FormRequest中重写错误处理的方法
2019/02/18 PHP
利用JQuery和JS实现奇偶行背景颜色自定义效果
2012/11/19 Javascript
jQuery中对节点进行操作的相关介绍
2013/04/16 Javascript
多个$(document).ready()的执行顺序实例分析
2014/07/26 Javascript
JavaScript严格模式详解
2015/11/18 Javascript
JQuery实现网页右侧随动广告特效
2016/01/17 Javascript
Angular.js实现动态加载组件详解
2017/05/28 Javascript
JavaScript中document.referrer的用法详解
2017/07/04 Javascript
收藏AngularJS中最重要的核心功能
2017/07/09 Javascript
JavaScript文件的同步和异步加载的实现代码
2017/08/19 Javascript
js实现单元格拖拽效果
2020/02/10 Javascript
[00:36]DOTA2风云人物相约完美“圣”典 12月17日不见不散
2016/11/30 DOTA
在Python中用keys()方法返回字典键的教程
2015/05/21 Python
apache部署python程序出现503错误的解决方法
2017/07/24 Python
由面试题加深对Django的认识理解
2019/07/19 Python
详解Anaconda 的安装教程
2020/09/23 Python
英国最红的高街时尚品牌:Topshop
2016/08/05 全球购物
Oracle的内存结构(Memory structures)
2015/06/10 面试题
最新远光软件笔试题面试题内容
2013/11/08 面试题
初中三好学生自我鉴定
2014/04/07 职场文书
新闻工作者先进事迹
2014/05/26 职场文书
预备党员个人总结
2015/02/14 职场文书
学校教师培训工作总结
2015/10/14 职场文书
学前班教学反思
2016/02/24 职场文书
2016年安全生产先进个人事迹材料
2016/02/29 职场文书
中学教代会开幕词
2016/03/04 职场文书
Android使用EventBus发送消息,Fragment中接收消息的方法会执行多次
2022/04/24 Java/Android