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

vue2實(shí)現(xiàn)無感刷新token的方式詳解

 更新時(shí)間:2024年02月28日 09:40:40   作者:江城開朗的豌豆  
在Web應(yīng)用中,用戶需要通過認(rèn)證和授權(quán)才能訪問受保護(hù)的資源,為了實(shí)現(xiàn)認(rèn)證和授權(quán)功能,通常需要使用Token來標(biāo)識(shí)用戶身份并驗(yàn)證其權(quán)限,本文給大家介紹了vue2實(shí)現(xiàn)無感刷新token的方式,需要的朋友可以參考下

引言:

在 Web 應(yīng)用中,用戶需要通過認(rèn)證和授權(quán)才能訪問受保護(hù)的資源。為了實(shí)現(xiàn)認(rèn)證和授權(quán)功能,通常需要使用 Token 來標(biāo)識(shí)用戶身份并驗(yàn)證其權(quán)限。但是,Token 有時(shí)限制其有效期,以確保安全性。

當(dāng) Token 過期時(shí),應(yīng)用程序會(huì)返回一個(gè) 401(未授權(quán))錯(cuò)誤,提示用戶重新登錄或刷新頁面。這可能會(huì)影響用戶體驗(yàn)和流程,并可能導(dǎo)致應(yīng)用程序的性能問題。

因此,為了提高應(yīng)用程序的用戶體驗(yàn)和可靠性,通常會(huì)使用無感刷新 Token 的技術(shù)來自動(dòng)刷新過期的 Token。這樣,即使 Token 過期,用戶也可以繼續(xù)使用應(yīng)用程序而不會(huì)收到任何干擾。此外,無感刷新 Token 還可以提高應(yīng)用程序的安全性和穩(wěn)定性,因?yàn)樗梢杂行У胤乐?Token 被惡意利用或攻擊。

需要注意的是,在實(shí)現(xiàn)無感刷新 Token 的過程中,需要注意保護(hù)用戶數(shù)據(jù)的安全性,并遵守相關(guān)的安全標(biāo)準(zhǔn)和法律法規(guī)。同時(shí),還需要根據(jù)應(yīng)用程序的需求和后端接口的設(shè)計(jì)來調(diào)整具體的實(shí)現(xiàn)方式。

安裝依賴

現(xiàn)在我們開始寫入vue2前端代碼

首先,確保已經(jīng)安裝了 Axios 和相關(guān)的依賴。

npm install axios

創(chuàng)建 Axios 實(shí)例并做請(qǐng)求封裝

在 src/utils/request.js 文件中創(chuàng)建一個(gè) Axios 實(shí)例,并進(jìn)行相關(guān)配置。

import axios from "axios";
 
const service = axios.create({
  baseURL:
    process.env.NODE_ENV !== "production"
      ? process.env.VUE_APP_BASE_API
      : process.env.VUE_APP_BASE_API_RUL,  
  timeout: 10000, // 超時(shí)時(shí)間
});
 
// request 攔截器
// 可以自請(qǐng)求發(fā)送前對(duì)請(qǐng)求做一些處理
// 比如統(tǒng)一加token,對(duì)請(qǐng)求參數(shù)統(tǒng)一加密
service.interceptors.request.use(
  (config) => {
    const token = window.localStorage.getItem("token");
    token && (config.headers.Authorization = token);
    config.headers["Content-Type"] = "application/json;charset=utf-8";
    config.headers["Authorization"] = "Bearer " + token; // 設(shè)置請(qǐng)求頭  
    return config;
  },
  (error) => {
    return Promise.reject("網(wǎng)絡(luò)異常,請(qǐng)稍后再試" + error);
  }
);
 
// response 攔截器
// 可以在接口響應(yīng)后統(tǒng)一處理結(jié)果
service.interceptors.response.use(
  (response) => {
    if (response.data.code == 401) {
      let userInfo = {};
      userInfo.account =  process.env.VUE_APP_TOKEN.split(",")[0];
      userInfo.password =  process.env.VUE_APP_TOKEN.split(",")[1];
      // 這里需要調(diào)用登錄接口,重新獲取token
      return refreshToken(userInfo).then((newToken) => {
        // 更新本地存儲(chǔ)的 Token       
        localStorage.setItem("token", newToken);
        // 重新發(fā)送原請(qǐng)求
        return service(response.config);
      });
    }
 
    let res = response.data;
    // 兼容服務(wù)端返回的字符串?dāng)?shù)據(jù)
    if (typeof res === "string") {
      res = res ? JSON.parse(res) : res;
    }
    return res;
  },
  (error) => {
    return Promise.reject("網(wǎng)絡(luò)異常,請(qǐng)稍后再試" + error);
  }
);
function refreshToken(userInfo) {
  return new Promise((resolve, reject) => {
    // 調(diào)用登錄接口重新獲取 Token
    axios  
      .post(`${process.env.VUE_APP_BASE_API}/pc_admin/login`, {    
        ...userInfo,
      })
      .then((response) => {
        resolve(response.data.data.token);
      })
      .catch((error) => {
        reject(error);
      });
  });
}
 
export default service;

使用封裝的 Axios 實(shí)例

在需要發(fā)送請(qǐng)求的地方引入封裝的 Axios 實(shí)例,并使用它來發(fā)送請(qǐng)求。

//sever.js
import request from "./http";
// 測試接口
export function getListApi(params) {
    return request({
        url: "/pc_admin/article", 
        method: "get",
        params: params,
    });
}
 

寫在最后

通過上述代碼,在使用 Axios 發(fā)送請(qǐng)求時(shí),會(huì)自動(dòng)處理 Token 過期的情況,并進(jìn)行無感刷新 Token。這樣可以提高應(yīng)用程序的用戶體驗(yàn)和安全性。

以上就是vue2實(shí)現(xiàn)無感刷新token的方式詳解的詳細(xì)內(nèi)容,更多關(guān)于vue2無感刷新token的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!

相關(guān)文章

  • Vue利用插件實(shí)現(xiàn)打印功能的示例詳解

    Vue利用插件實(shí)現(xiàn)打印功能的示例詳解

    這篇文章主要為大家詳細(xì)介紹了Vue如何利用vue-print-nb插件實(shí)現(xiàn)打印功能,文中的示例代碼講解詳細(xì),感興趣的小伙伴可以跟隨小編一起學(xué)一下
    2023-03-03
  • Vue.js對(duì)象轉(zhuǎn)換實(shí)例

    Vue.js對(duì)象轉(zhuǎn)換實(shí)例

    這篇文章主要介紹了 Vue.js對(duì)象轉(zhuǎn)換的相關(guān)資料,非常不錯(cuò),具有參考借鑒價(jià)值,需要的朋友可以參考下
    2017-06-06
  • Vue自定義指令實(shí)現(xiàn)卡片翻轉(zhuǎn)功能

    Vue自定義指令實(shí)現(xiàn)卡片翻轉(zhuǎn)功能

    這篇文章主要給大家介紹了Vue自定義指令實(shí)現(xiàn)卡片翻轉(zhuǎn)功能的代碼示例,文章通過代碼示例講解的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作有一定的參幫助,需要的朋友可以參考下
    2023-11-11
  • mapbox gl開箱即用的地圖引擎庫

    mapbox gl開箱即用的地圖引擎庫

    這篇文章主要為大家介紹了一款mapbox gl開箱即用的地圖引擎庫,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-07-07
  • Vue3使用ref解決GetElementById為空的問題

    Vue3使用ref解決GetElementById為空的問題

    今天遇到一個(gè)問題,就是在Vue3組件中需要獲取template中的元素節(jié)點(diǎn),使用GetElementById返回的卻是null,網(wǎng)上查找了好些資料,才發(fā)需要使用ref,所以本文給大家介紹了Vue3組件中如何使用ref解決GetElementById為空的問題,需要的朋友可以參考下
    2023-12-12
  • 優(yōu)雅的elementUI table單元格可編輯實(shí)現(xiàn)方法詳解

    優(yōu)雅的elementUI table單元格可編輯實(shí)現(xiàn)方法詳解

    這篇文章主要介紹了優(yōu)雅的elementUI table單元格可編輯實(shí)現(xiàn)方法詳解,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2018-12-12
  • vue?table表格中如何控制下拉框的顯示隱藏

    vue?table表格中如何控制下拉框的顯示隱藏

    這篇文章主要介紹了vue?table表格中如何控制下拉框的顯示隱藏問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-01-01
  • Vue之文件加載執(zhí)行全流程

    Vue之文件加載執(zhí)行全流程

    這篇文章主要介紹了Vue之文件加載執(zhí)行全流程,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-04-04
  • ant design vue 表格table 默認(rèn)勾選幾項(xiàng)的操作

    ant design vue 表格table 默認(rèn)勾選幾項(xiàng)的操作

    這篇文章主要介紹了ant design vue 表格table 默認(rèn)勾選幾項(xiàng)的操作,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧
    2020-10-10
  • 詳解Vue2 添加對(duì)scss的支持

    詳解Vue2 添加對(duì)scss的支持

    這篇文章主要介紹了詳解Vue2 添加對(duì)scss的支持,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2019-01-01

最新評(píng)論