欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

關(guān)于401狀態(tài)碼的含義和處理方式

 更新時間:2022年08月16日 10:21:41   作者:木藍茶陌*_*  
這篇文章主要介紹了關(guān)于401狀態(tài)碼的含義和處理方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教

401狀態(tài)碼的含義和處理

401狀態(tài)碼的含義

axios向服務器端發(fā)送請求時,有兩種情況會出現(xiàn)401狀態(tài)碼(unauthorized未授權(quán)):

1. 服務端要求傳遞token信息,而實際發(fā)送請求時沒有傳遞。

2. 發(fā)送請求時有傳遞token到達服務器端,但由于時間比較久,這個token在服務器中已經(jīng)過期了(服務器存儲token有效期時間為2個小時)。

總之,服務器端有些api接口要求傳遞token,token失效或沒有傳遞,就會報401錯誤。

401狀態(tài)碼的處理

1. 在axios請求攔截器中做token傳遞操作。

2. 可以這樣設(shè)置,在axios響應攔截器中判斷請求狀態(tài)如果是401,就強制用戶重新登錄系統(tǒng)。

第2種情況處理實現(xiàn):

在axios的響應攔截器中,判斷錯誤碼等于401就強制登錄(utils/ax.js)

// 引入路由
import router from '@/router'
// 配置響應攔截器
axios.interceptors.response.use(function (response) {
? // 正常響應處理
? return response
}, function (error) {
? // 非正常響應處理(包括401)
? // console.dir(error) // 對象: config request response isAxiosError toJSON
? if (error.response.status === 401) {
? ? // token失效(token在服務器端已經(jīng)失效了,2個小時時效)
? ? // 強制用戶重新登錄系統(tǒng),以刷新服務器端的token時效
? ? router.push('/login')
? ? // 不要給做錯誤提示了
? ? return new Promise(function () {}) // 空的Promise對象,沒有機會執(zhí)行catch,進而不做錯誤提示了
? }
? // return new Promise((resolve,reject)=>{
? // reject('獲得文章失敗!')
? // })
? return Promise.reject(error)
})

注意:

1. 路由對象.push(xxx) 可以實現(xiàn)編程式導航。

2. 路由對象:在組件中是 this.$router ,在main.js/ax.js文件中就是router對象(需要import導入)。

模擬服務器端token失效步驟:

1. 刪除客戶端sessionStorage數(shù)據(jù)。

2. 暫時屏蔽守衛(wèi)代碼(開發(fā)完畢再打開)。

401狀態(tài)碼升級處理

401狀態(tài)碼

axios向服務器端發(fā)送請求時有兩種情況會出現(xiàn)401狀態(tài)碼(unauthorized未授權(quán)):

1. 服務端要求傳遞token信息,而實際沒有傳遞。

2. 有傳遞token到達服務器端,但由于時間比較久,這個token在服務器中已經(jīng)過期了(服務器存儲token有效期時間為2個小時)。

總之,服務器端有些api接口要求傳遞token,token失效或沒有傳遞,就會報401錯誤。

相關(guān)處理

1. 第1種情況,可以在axios請求攔截器中做token傳遞操作。

2. 第2種情況,之前是這樣處理的,在axios響應攔截器中判斷請求狀態(tài)如果是401,就強制用戶重新登錄系統(tǒng)

這樣處理用戶體驗非常不好,現(xiàn)在做一次升級優(yōu)化處理。 

服務器端返回兩個秘鑰信息,它們在服務端都有使用時效:

  • token 有效期2小時。
  • refresh_token 有效期14天,refresh_token用于在token過期后,重新獲取并刷新token時效使用的。

針對第2種401狀態(tài)碼處理步驟為:

1. 判斷refresh_token是否存在

不存在就直接重新登錄。

存在,axios發(fā)起請求,帶著refresh_token請求服務端,獲取新token出來:

成功:對vuex和localStorage進行token信息更新。

失?。呵蹇諢o效用戶信息,直接重新登錄。

示例代碼1 

// 響應攔截器 (響應成功:剝離無效數(shù)據(jù),響應失?。核⑿聇oken)
instance.interceptors.response.use(res => {
  // 將來獲取數(shù)據(jù):res.data.data 麻煩
  // 想要結(jié)果:data 即可
  try {
    return res.data.data
  } catch (e) {
    return res
  }
}, async err => {
  try {
    // 目的:刷新token
    if (err.response && err.response.status === 401) {
    // 未登錄  跳轉(zhuǎn)登錄頁面  阻止程序運行
      const { user } = store.state
      // 如果沒有token沒登錄  如果沒有refresh_token無法刷新token
      if (!user.token || !user.refresh_token) {
        router.push('/login')
        return Promise.reject(err)
      }
      // 刷新token,發(fā)請求,沒有配置的axios,自己配置refresh_token
      const res = await axios({
        url: 'http://ttapi.research.itcast.cn/app/v1_0/authorizations',
        method: 'put',
        headers: {
          Authorization: `Bearer ${user.refresh_token}`
        }
      })
      // token獲取  res.data.data.token
      // 更新 vuex 和 本地 token
      store.commit('setUser', {
        token: res.data.data.token,
        refresh_token: user.refresh_token
      })
      // 繼續(xù)發(fā)送剛才錯誤的請求
      // instance({之前錯誤的請求配置})
      // err錯誤對象 包含(response 響應對象 |config 請求配置)
      return instance(err.config)
    }
  } catch (e) { // exception 異常
    // 刷新token失敗
    router.push('/login')
    return Promise.reject(e)
  }
  return Promise.reject(err)
})

演示代碼:promise錯誤處理:

示例代碼2

import store from '@/store' // 引入vuex中的store實例
import router from '@/router' // 引入路由對象實例
……
// 響應攔截器
instance.interceptors.response.use(
  function (response) {
    try {
      // 返回具體有價值的業(yè)務數(shù)據(jù)
      return response.data.data
    } catch (error) {
      return response.data
    }
  },
  async function (error) {
    // 響應有錯誤,有可能錯誤狀態(tài)碼為401
    if (error.response && error.response.status === 401) {
      // 定義登錄路由對象
      let toPath = {
        name: 'login',
        query: { redirectUrl: router.currentRoute.path }
      } // 跳轉(zhuǎn)對象
      // 如果refresh_token不存在
      if (!store.state.user.refresh_token) {
        router.push(toPath)
        return Promise.reject(error)
      }
      try {
        // 刷新用戶token
        // 應該發(fā)送一個請求 換取新的token
        // 這里不應該再用instance  因為 instance會再次進入攔截器  用默認的axios
        let result = await axios({
          method: 'put',
          url: 'http://ttapi.research.itcast.cn/app/v1_0/authorizations',
          headers: {
            Authorization: `Bearer ${store.state.user.refresh_token}`
          }
        })
        // 獲取到新token后,就對vuex和localStorage進行更新
        store.commit('updateUser', {
          token: result.data.data.token, // 拿到新的token之后
          refresh_token: store.state.user.refresh_token // 將之前 refresh_token 14天有效期
        })
        return instance(error.config) // 把剛才錯誤的請求再次發(fā)送出去 然后將promise返回
      } catch (err) {
        // 如果錯誤 表示補救措施也沒用了(有可能refresh_token也失效了)
        // 應該跳轉(zhuǎn)到登錄頁 并且 把廢掉的用戶信息全都干掉
        store.commit('clearUser') // 所有的用戶信息清空
        router.push(toPath) // 跳轉(zhuǎn)到回登錄頁
        return Promise.reject(err)
      }
    }
    return Promise.reject(error)
  }
)
') // 所有的用戶信息清空
        router.push(toPath) // 跳轉(zhuǎn)到回登錄頁
        return Promise.reject(err)
      }
    }
    return Promise.reject(error)
  }
)

以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。 

相關(guān)文章

  • 解決VS2017不能打開stdio.h等文件的問題

    解決VS2017不能打開stdio.h等文件的問題

    下面小編就為大家?guī)硪黄鉀QVS2017不能打開stdio.h等文件的問題。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-07-07
  • MAC系統(tǒng)IDEA顏值插件MaterialThemeUI

    MAC系統(tǒng)IDEA顏值插件MaterialThemeUI

    俗話說,工欲善其事必先利其器。工具的顏值也很重要,好的主題讓人賞心悅目,有碼代碼的欲望。今天推薦一個IDEA顏值類插件:Material Theme UI
    2021-09-09
  • 詳解vscode使用git所遇到的坑

    詳解vscode使用git所遇到的坑

    這篇文章主要介紹了詳解vscode使用git所遇到的坑,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2020-08-08
  • Git 如何放棄所有本地修改的方法

    Git 如何放棄所有本地修改的方法

    這篇文章主要介紹了Git 如何放棄所有本地修改的方法,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2020-11-11
  • HTTP 2.0 詳細介紹

    HTTP 2.0 詳細介紹

    本文主要介紹 HTTP 2.0的知識,這里整理了詳細的資料,并對HTTP2.0的知識做了詳解,有需要的小伙伴可以參考下
    2016-09-09
  • 關(guān)于Unity動畫狀態(tài)機Animator使用教程

    關(guān)于Unity動畫狀態(tài)機Animator使用教程

    這篇文章主要介紹了關(guān)于Unity動畫狀態(tài)機Animator的使用教程,有需要的朋友可以借鑒參考下,希望可以對廣大讀者朋友能夠有所幫助
    2021-09-09
  • VScode中集成Git命令詳解

    VScode中集成Git命令詳解

    本文詳細講解了VScode中集成Git命令的方法,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2022-06-06
  • git log根據(jù)特定條件查詢?nèi)罩静⒔y(tǒng)計修改的代碼行數(shù)

    git log根據(jù)特定條件查詢?nèi)罩静⒔y(tǒng)計修改的代碼行數(shù)

    這篇文章主要介紹了git log根據(jù)特定條件查詢?nèi)罩静⒔y(tǒng)計修改的代碼行數(shù),本文給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2020-09-09
  • 遇到不能復制的網(wǎng)站怎么辦?

    遇到不能復制的網(wǎng)站怎么辦?

    有時我們看到喜歡的網(wǎng)頁內(nèi)容時定會產(chǎn)生復制下來為我所用的沖動,不過當你點擊鼠標時它卻沒有任何反應,選擇的內(nèi)容沒有任何變化,不禁有點掃興。不要緊,辦法總比困難多!
    2009-06-06
  • Postman配置多環(huán)境請求地址的實現(xiàn)

    Postman配置多環(huán)境請求地址的實現(xiàn)

    本文主要介紹了Postman配置多環(huán)境請求地址的實現(xiàn),文中通過示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-01-01

最新評論