vue2實(shí)現(xiàn)無感刷新token的方式詳解
引言:
在 Web 應(yīng)用中,用戶需要通過認(rèn)證和授權(quán)才能訪問受保護(hù)的資源。為了實(shí)現(xiàn)認(rèn)證和授權(quán)功能,通常需要使用 Token 來標(biāo)識用戶身份并驗(yàn)證其權(quán)限。但是,Token 有時限制其有效期,以確保安全性。
當(dāng) Token 過期時,應(yīng)用程序會返回一個 401(未授權(quán))錯誤,提示用戶重新登錄或刷新頁面。這可能會影響用戶體驗(yàn)和流程,并可能導(dǎo)致應(yīng)用程序的性能問題。
因此,為了提高應(yīng)用程序的用戶體驗(yàn)和可靠性,通常會使用無感刷新 Token 的技術(shù)來自動刷新過期的 Token。這樣,即使 Token 過期,用戶也可以繼續(xù)使用應(yīng)用程序而不會收到任何干擾。此外,無感刷新 Token 還可以提高應(yīng)用程序的安全性和穩(wěn)定性,因?yàn)樗梢杂行У胤乐?Token 被惡意利用或攻擊。
需要注意的是,在實(shí)現(xiàn)無感刷新 Token 的過程中,需要注意保護(hù)用戶數(shù)據(jù)的安全性,并遵守相關(guān)的安全標(biāo)準(zhǔn)和法律法規(guī)。同時,還需要根據(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í)例并做請求封裝
在 src/utils/request.js 文件中創(chuàng)建一個 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, // 超時時間
});
// request 攔截器
// 可以自請求發(fā)送前對請求做一些處理
// 比如統(tǒng)一加token,對請求參數(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è)置請求頭
return config;
},
(error) => {
return Promise.reject("網(wǎng)絡(luò)異常,請稍后再試" + 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) => {
// 更新本地存儲的 Token
localStorage.setItem("token", newToken);
// 重新發(fā)送原請求
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ò)異常,請稍后再試" + 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ā)送請求的地方引入封裝的 Axios 實(shí)例,并使用它來發(fā)送請求。
//sever.js
import request from "./http";
// 測試接口
export function getListApi(params) {
return request({
url: "/pc_admin/article",
method: "get",
params: params,
});
}
寫在最后
通過上述代碼,在使用 Axios 發(fā)送請求時,會自動處理 Token 過期的情況,并進(jìn)行無感刷新 Token。這樣可以提高應(yīng)用程序的用戶體驗(yàn)和安全性。
以上就是vue2實(shí)現(xiàn)無感刷新token的方式詳解的詳細(xì)內(nèi)容,更多關(guān)于vue2無感刷新token的資料請關(guān)注腳本之家其它相關(guān)文章!
- vue中雙token和無感刷新token的區(qū)別
- Vue實(shí)現(xiàn)雙token無感刷新的示例代碼
- VUE前端實(shí)現(xiàn)token的無感刷新方式
- vuex刷新頁面丟失登錄token信息的解決方案
- Vue項(xiàng)目實(shí)現(xiàn)token無感刷新的示例代碼
- 前端使用vue實(shí)現(xiàn)token無感刷新的三種方案解析
- Vue3+Vite使用雙token實(shí)現(xiàn)無感刷新
- 關(guān)于Vue 消除Token過期時刷新頁面的重復(fù)提示問題
- vue的token刷新處理的方法
- Vue項(xiàng)目中實(shí)現(xiàn)無感Token刷新的示例
相關(guān)文章
Vue自定義指令實(shí)現(xiàn)卡片翻轉(zhuǎn)功能
這篇文章主要給大家介紹了Vue自定義指令實(shí)現(xiàn)卡片翻轉(zhuǎn)功能的代碼示例,文章通過代碼示例講解的非常詳細(xì),對大家的學(xué)習(xí)或工作有一定的參幫助,需要的朋友可以參考下2023-11-11
Vue3使用ref解決GetElementById為空的問題
今天遇到一個問題,就是在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)方法詳解,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2018-12-12
ant design vue 表格table 默認(rèn)勾選幾項(xiàng)的操作
這篇文章主要介紹了ant design vue 表格table 默認(rèn)勾選幾項(xiàng)的操作,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2020-10-10

