亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

請求時token過期自動刷新token操作

 更新時間:2020年09月11日 15:24:44   作者:江湖小浪蝦  
這篇文章主要介紹了請求時token過期自動刷新token操作,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧

1.在開發(fā)過程中,我們都會接觸到token,token的作用是什么呢?主要的作用就是為了安全,用戶登陸時,服務器會隨機生成一個有時效性的token,用戶的每一次請求都需要攜帶上token,證明其請求的合法性,服務器會驗證token,只有通過驗證才會返回請求結果。

2.當token失效時,現(xiàn)在的網(wǎng)站一般會做兩種處理,一種是跳轉到登陸頁面讓用戶重新登陸獲取新的token,另外一種就是當檢測到請求失效時,網(wǎng)站自動去請求新的token,第二種方式在app保持登陸狀態(tài)上面用得比較多。

3.下面進入主題,我們請求用的是axios,不管用何種請求方式,刷新token的原理都是一樣的。

//封裝了一個統(tǒng)一的請求函數(shù),這個不是重點

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));
}

// 封裝了一個檢測返回結果的函數(shù),與后臺返回狀態(tài)碼code === 1002表示token失效

let isRefreshing = true;
function checkStatus(response) {
 if (response && response.code === 1002) {
  // 刷新token的函數(shù),這需要添加一個開關,防止重復請求
  if(isRefreshing){
    refreshTokenRequst()
  }
  isRefreshing = false;
  // 這個Promise函數(shù)很關鍵
   const retryOriginalRequest = new Promise((resolve) => {
        addSubscriber(()=> {
          resolve(request(url, options))
        })
      });
      return retryOriginalRequest;
 }else{
   return response;
 }
}

// 刷新token的請求函數(shù)

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函數(shù)集合

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

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

總結:

其實token失效,自動刷新token,在頁面只有一個請求的時候是比較好處理的,但是如果頁面同時有多個請求,并且都會產(chǎn)生token失效,這就需要一些稍微復雜的處理,解決方式主要是用了Promise 函數(shù)來進行處理。

每一個token失效的請求都會存到一個Promise函數(shù)集合里面,當刷新token的函數(shù)執(zhí)行完畢后,才會批量執(zhí)行這些Promise函數(shù),返回請求結果。

還有一點要注意一下,這兒設置一個刷新token的開關isRefreshing,這個是非常有必要的,防止重復請求。

以上這篇請求時token過期自動刷新token操作就是小編分享給大家的全部內(nèi)容了,希望能給大家一個參考,也希望大家多多支持腳本之家。

相關文章

  • 再談javascript圖片預加載技術(詳細演示)

    再談javascript圖片預加載技術(詳細演示)

    由于javascript無法獲取img文件頭數(shù)據(jù),必須等待其加載完畢后才能獲取真實的大小,所以lightbox類效果為了讓圖片居中顯示,導致其速度體驗要比直接輸出的差很多。
    2011-03-03
  • 詳解用async/await來處理異步

    詳解用async/await來處理異步

    這篇文章主要介紹了詳解用async/await來處理異步,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2019-08-08
  • JavaScript中的閉包介紹

    JavaScript中的閉包介紹

    這篇文章主要介紹了JavaScript中的閉包介紹,本文講解了Javacript 閉包、Javscript 閉包與this、Javscript 閉包與讀寫變量等內(nèi)容,需要的朋友可以參考下
    2015-03-03
  • JS實現(xiàn)touch 點擊滑動輪播實例代碼

    JS實現(xiàn)touch 點擊滑動輪播實例代碼

    這篇文章主要介紹了JS實現(xiàn)touch 點擊滑動輪播實例代碼,需要的朋友可以參考下
    2017-01-01
  • 淺談JS三座大山之異步和單線程

    淺談JS三座大山之異步和單線程

    首先我們要知道,js這門語言是單線程的,同時只能做一件事,比如說渲染dom,執(zhí)行js方法,這些事情只能一個一個做,不能分開執(zhí)行。(因為js需要操作dom,當兩個js方法同時操作一個dom的時候就會出問題,所以js被設計成了單線程)。本文將介紹JS三座大山之異步和單線程。
    2021-06-06
  • 基于JS實現(xiàn)仿京東搜索欄隨滑動透明度漸變效果

    基于JS實現(xiàn)仿京東搜索欄隨滑動透明度漸變效果

    這篇文章主要介紹了基于JS實現(xiàn)仿京東搜索欄隨滑動透明度漸變效果,代碼簡單易懂,非常不錯,具有參考借鑒價值,需要的朋友可以參考下
    2017-07-07
  • CSS javascript 結合實現(xiàn)懸浮固定菜單效果

    CSS javascript 結合實現(xiàn)懸浮固定菜單效果

    本篇文章給大家介紹基于CSS javascript 結合實現(xiàn)懸浮固定菜單效果,附有源碼下載,需要的朋友可以參考下
    2015-08-08
  • JS文件上傳神器bootstrap fileinput詳解

    JS文件上傳神器bootstrap fileinput詳解

    這篇文章主要介紹了JS文件上傳神器Bootstrap FileInput,樣式非常美觀,并且支持上傳文件預覽,ajax同步或異步上傳,拖曳文件上傳等炫酷的功能,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2016-11-11
  • JavaScript實現(xiàn)時鐘滴答聲效果

    JavaScript實現(xiàn)時鐘滴答聲效果

    本文給大家分享一段js實例代碼實現(xiàn)時鐘滴答聲效果,效果逼真,非常不錯,具有參考借鑒價值,需要的朋友參考下吧
    2017-01-01
  • 在js文件中如何獲取basePath處理js路徑問題

    在js文件中如何獲取basePath處理js路徑問題

    在jsp中,我們可以用el表達式直接獲取basePath,但是在單獨js文件中不能用el表達式,下面與大家分享下js文件中如何獲取basePath,感興趣的朋友可以參考下
    2013-07-07

最新評論