当前位置: 移动技术网 > IT编程>开发语言>Java > 请求时token过期自动刷新token操作

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

2020年09月11日  | 移动技术网IT编程  | 我要评论
1.在开发过程中,我们都会接触到token,token的作用是什么呢?主要的作用就是为了安全,用户登陆时,服务器会随机生成一个有时效性的token,用户的每一次请求都需要携带上token,证明其请求的

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操作就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持移动技术网。

如您对本文有疑问或者有任何想说的,请点击进行留言回复,万千网友为您解惑!

相关文章:

验证码:
移动技术网