vue同一瀏覽器登錄多賬號(hào)處理方案
vue同一瀏覽器登錄多賬號(hào)處理
背景
項(xiàng)目在線上會(huì)遇到管理員類似權(quán)限比較大的用戶,會(huì)在同一瀏覽器登陸多個(gè)賬號(hào)。由于后端是通過cookie識(shí)別,此時(shí)cookie已經(jīng)是最新登陸賬號(hào)信息。管理員有可能切換tab至之前頁面,此時(shí)頁面顯示還是之前信息,當(dāng)修改信息,提交請(qǐng)求時(shí),其實(shí)后端是按照最新登陸用戶進(jìn)行信息處理的。這種情況下,容易誤導(dǎo)用戶,造成錯(cuò)誤的信息修改。
解決
前端種個(gè)cookie,監(jiān)聽頁面tab切換事件,通過接口返回的id與cookie中的id對(duì)比,若不一致,則提示用戶刷新頁面,頁面重新渲染,展示的就是最新登陸用戶的信息了
具體實(shí)現(xiàn)
store.js
// 裝js-cookie種cookie
import Cookies from 'js-cookie';
// 每次登錄的時(shí)候,通過接口獲取當(dāng)前登錄賬號(hào)的LoginName
getLoginName() {
return api
.getLoginName()
.then((res) => {
if (res.status === 0) {
// 這里通過vuex存下來 在app.vue里使用(項(xiàng)目本身已使用vuex 沒有的話可以參考vue組件通信)
commit('RECORD_LOGIN_NAME', res.loginName);
// 拿到結(jié)果,存到cookie里
this.loginName = res.loginName
Cookies.set('loginName', res.loginName);
}
})
.catch((e) => {
return false;
});
},app.vue
在入口頁添加監(jiān)聽頁面tab切換的事件
export default{
data () {
return {
isConfirmShow: false,
};
},
methods: {
checkNameExpired() {
// this.loginName:接口請(qǐng)求獲取name的存下來
const loginName_cookie = Cookie.get('loginName');
if (this.loginName !== loginName_cookie && !this.isConfirmShow) {
this.isConfirmShow = true;
// 這里樣式可以根據(jù)項(xiàng)目?jī)?yōu)化
alert(`已登錄${loginName_cookie},點(diǎn)擊 “確定” 刷新本頁面。`);
window.location.reload();
this.isConfirmShow = false;
}
}
},
mounted() {
document.addEventListener('visibilitychange', this.checkNameExpired);
},
beforeDestroy() {
document.removeEventListener('visibilitychange', this.checkNameExpired);
}
};補(bǔ)充:
vue項(xiàng)目中實(shí)現(xiàn)同一個(gè)瀏覽器登錄多個(gè)用戶賬號(hào)
需求
同一個(gè)瀏覽器兩個(gè)tab分別登錄A和B兩個(gè)賬號(hào)
問題描述
用戶登錄會(huì)在緩存中存token,鍵名都是一樣的,所以會(huì)出現(xiàn)A用戶登錄,后在另外一個(gè)tab里登錄B用戶,A用戶再訪問接口的時(shí)候,其實(shí)是用的B用戶的token,因?yàn)槊總€(gè)用戶的權(quán)限不一樣,這樣就照成了bug
解決思路
讓不同的用戶存儲(chǔ)的token的鍵名不一樣
實(shí)現(xiàn)方法 在登錄的時(shí)候存儲(chǔ)用TOKEN+userName作為鍵來存儲(chǔ)token
import Cookies from 'js-cookie'
import Config from '@/config'
const TokenKey = Config.TokenKey;
export function getToken() {
return Cookies.get( TokenKey + sessionStorage.getItem( 'username' ) )
}
export function setToken( token, rememberMe, username ) {
if ( rememberMe ) {
return Cookies.set( TokenKey + username, token, { expires: Config.tokenCookieExpires } )
} else {
return Cookies.set( TokenKey + username, token )
}
}
export function removeToken( username ) {
return Cookies.remove( TokenKey + username )
}頁面刷新前存儲(chǔ)用戶名
window.addEventListener("beforeunload", () => {
sessionStorage.setItem("username", this.user.username || "");
});到此這篇關(guān)于vue同一瀏覽器登錄多賬號(hào)處理的文章就介紹到這了,更多相關(guān)vue同一瀏覽器登錄多賬號(hào)內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
- Vue實(shí)現(xiàn)用戶沒有登陸時(shí),訪問后自動(dòng)跳轉(zhuǎn)登錄頁面的實(shí)現(xiàn)思路
- Vue項(xiàng)目如何保持用戶登錄狀態(tài)(localStorage+vuex刷新頁面后狀態(tài)依然保持)
- vue實(shí)現(xiàn)用戶長時(shí)間不操作自動(dòng)退出登錄功能的實(shí)現(xiàn)代碼
- vue 實(shí)現(xiàn)用戶登錄方式的切換功能
- VuePress 中如何增加用戶登錄功能
- VUE:vuex 用戶登錄信息的數(shù)據(jù)寫入與獲取方式
- vue同一個(gè)瀏覽器登錄不同賬號(hào)數(shù)據(jù)覆蓋問題解決方案
- vue?+elementui?項(xiàng)目登錄通過不同賬號(hào)切換側(cè)邊欄菜單的顏色
- Vue實(shí)現(xiàn)登錄記住賬號(hào)密碼功能的思路與過程
- vue項(xiàng)目實(shí)現(xiàn)表單登錄頁保存賬號(hào)和密碼到cookie功能
相關(guān)文章
vue-cli是什么及創(chuàng)建vue-cli項(xiàng)目的方法
vue-cli是 vue 官方提供的、快速生成 vue 工程化項(xiàng)目的工具,支持創(chuàng)建vue2和vue3的項(xiàng)目,本文給大家詳細(xì)講解vue-cli是什么及創(chuàng)建vue-cli項(xiàng)目的方法,感興趣的朋友跟隨小編一起看看吧2023-04-04
Vue3中使用reactive時(shí),后端有返回?cái)?shù)據(jù)但dom沒有更新的解決
這篇文章主要介紹了Vue3中使用reactive時(shí),后端有返回?cái)?shù)據(jù)但dom沒有更新的解決,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-03-03
vue3使用xgPalyer實(shí)現(xiàn)截圖功能的方法詳解
這篇文章主要為大家詳細(xì)介紹了如何在vue3中使用xgPalyer截圖功能,以及自定義插件,文中的示例代碼講解詳細(xì),感興趣的小伙伴可以跟隨小編一起學(xué)習(xí)一下2024-02-02
vue實(shí)現(xiàn)各種文件文檔下載及導(dǎo)出示例
這篇文章主要介紹了vue實(shí)現(xiàn)各種文件文檔下載及導(dǎo)出示例,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-06-06
vue-cli3.0+element-ui上傳組件el-upload的使用
這篇文章主要介紹了vue-cli3.0+element-ui上傳組件el-upload的使用,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2018-12-12
淺談vue中$event理解和框架中在包含默認(rèn)值外傳參
這篇文章主要介紹了淺談vue中$event理解和框架中在包含默認(rèn)值外傳參,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2020-08-08
JavaScript之實(shí)現(xiàn)一個(gè)簡(jiǎn)單的Vue示例
這篇文章主要介紹了JavaScript之實(shí)現(xiàn)一個(gè)簡(jiǎn)單的Vue示例,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2019-01-01

