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

vue同一瀏覽器登錄多賬號(hào)處理方案

 更新時(shí)間:2024年01月19日 11:53:44   作者:九段刀客  
項(xiàng)目在線上會(huì)遇到管理員類似權(quán)限比較大的用戶,會(huì)在同一瀏覽器登陸多個(gè)賬號(hào),遇到這樣的問題如何處理呢,下面小編給大家介紹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分別登錄AB兩個(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)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • Vue 實(shí)現(xiàn)輪播圖功能的示例代碼

    Vue 實(shí)現(xiàn)輪播圖功能的示例代碼

    Vue是一款流行的前端框架,它提供了一系列的工具和組件,使得開發(fā)者可以更加便捷地創(chuàng)建交互式的Web應(yīng)用程序,輪播圖是Web應(yīng)用程序中常見的一種交互式組件,本文將介紹如何使用Vue和第三方組件庫 Element UI實(shí)現(xiàn)輪播圖功能,需要的朋友可以參考下
    2023-05-05
  • vue-cli是什么及創(chuàng)建vue-cli項(xiàng)目的方法

    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沒有更新的解決

    這篇文章主要介紹了Vue3中使用reactive時(shí),后端有返回?cái)?shù)據(jù)但dom沒有更新的解決,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-03-03
  • vue3使用xgPalyer實(shí)現(xiàn)截圖功能的方法詳解

    vue3使用xgPalyer實(shí)現(xiàn)截圖功能的方法詳解

    這篇文章主要為大家詳細(xì)介紹了如何在vue3中使用xgPalyer截圖功能,以及自定義插件,文中的示例代碼講解詳細(xì),感興趣的小伙伴可以跟隨小編一起學(xué)習(xí)一下
    2024-02-02
  • Vue中的偵聽器及使用場(chǎng)景

    Vue中的偵聽器及使用場(chǎng)景

    Vue中的偵聽器是一種響應(yīng)式機(jī)制,可以對(duì)指定的數(shù)據(jù)進(jìn)行監(jiān)聽,并在數(shù)據(jù)變化時(shí)執(zhí)行相應(yīng)的回調(diào)函數(shù)。常用于監(jiān)聽復(fù)雜數(shù)據(jù)類型的變化,如對(duì)象和數(shù)組。通過偵聽器,可以實(shí)現(xiàn)數(shù)據(jù)的自動(dòng)更新和邏輯處理等功能,提高代碼的可讀性和可維護(hù)性
    2023-05-05
  • vue實(shí)現(xiàn)各種文件文檔下載及導(dǎo)出示例

    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的使用

    這篇文章主要介紹了vue-cli3.0+element-ui上傳組件el-upload的使用,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2018-12-12
  • 淺談vue中$event理解和框架中在包含默認(rèn)值外傳參

    淺談vue中$event理解和框架中在包含默認(rèn)值外傳參

    這篇文章主要介紹了淺談vue中$event理解和框架中在包含默認(rèn)值外傳參,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧
    2020-08-08
  • vue路由傳參三種基本方式詳解

    vue路由傳參三種基本方式詳解

    這篇文章主要介紹了vue路由傳參三種基本方式詳解,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2019-12-12
  • JavaScript之實(shí)現(xiàn)一個(gè)簡(jiǎn)單的Vue示例

    JavaScript之實(shí)現(xiàn)一個(gè)簡(jiǎn)單的Vue示例

    這篇文章主要介紹了JavaScript之實(shí)現(xiàn)一個(gè)簡(jiǎn)單的Vue示例,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2019-01-01

最新評(píng)論