成人国产在线小视频_日韩寡妇人妻调教在线播放_色成人www永久在线观看_2018国产精品久久_亚洲欧美高清在线30p_亚洲少妇综合一区_黄色在线播放国产_亚洲另类技巧小说校园_国产主播xx日韩_a级毛片在线免费

資訊專欄INFORMATION COLUMN

關(guān)于同一賬號多人同時登錄的token重復(fù)問題

Gemini / 1533人閱讀

摘要:最近在項目上遇到了一個同一賬號多終端或者說多用戶同時登錄導(dǎo)致的重復(fù)問題。修改后的偽代碼如下同一賬號不能同時登錄用戶不存在當(dāng)有兩個線程進入到,第一個線程會修改版本號并插入,而第二個線程則會因為版本號不一致,拋出異常。

最近在項目上遇到了一個同一賬號多終端(或者說多用戶)同時登錄導(dǎo)致的token重復(fù)問題。可以在瀏覽器相應(yīng)地做一些防止表單重復(fù)提交的操作,比如登錄按鈕點擊一次后變成不可點擊的狀態(tài),等待服務(wù)器的響應(yīng)之后再恢復(fù)成點擊狀態(tài)。不過這也并不能解決同一賬號多終端登錄的問題。

https://github.com/bluesnail9...

項目中的偽代碼如下:
User user = getUser(username,password);
if(null != user) {
    String token = findToken(user);
    if(null != token) {
    user.deleteToken(user);
        token = null;
    }
    if(null == token){
        user.insertNewToken(user);
    }    
}else {
    throw new Exception("用戶不存在");
}
想一想:

為什么會出現(xiàn)token重復(fù)的問題?因為同一賬號多用戶(或者多終端)同時登錄時都進入到了if(null == token)這個語句,所以就向數(shù)據(jù)庫中插入了多個token,但是按道理,一個賬號,只能對應(yīng)一個token。

那如何解決這個問題呢?

(1)我開始想到的是做一個同步,用synchronized同步語句塊。

User user = getUser(username,password);
if(null != user) {
    //使用synchronized做同步
    synchronized(username.intern()){
        String token = findToken(user);
        if(null != token) {
        user.deleteToken(user);
            token = null;
        }
        if(null == token){
            user.insertNewToken(user);
        }     
    }
}else {
    throw new Exception("用戶不存在");
}

synchronized括號里的內(nèi)容應(yīng)該寫什么呢?User實例(對象)?每個線程的User實例都是不一樣的。username變量?試了不起作用。username并不是在編譯期就可知的,而是在運行期從瀏覽器傳遞到后臺。修改成username.intern()是可以成功的,intern()方法會在常量池中查找和創(chuàng)建字符串。

(2)使用鎖ReentrantLock做同步

//定義鎖
private ReentrantLock lock = new ReentrantLock();
User user = getUser(username,password);
if(null != user) {  
    try{
        //獲取鎖
        lock.lock();
        String token = findToken(user);
        if(null != token) {
        user.deleteToken(user);
            token = null;
        }
        if(null == token){
            user.insertNewToken(user);          
        }     
    }catch(Exception e) {
        e.printStackTrace();
    }finally {
        //釋放鎖
        lock.unlock();
    }
}

注意:定義一個私有公共的ReentrantLock,獲取鎖是調(diào)用lock()方法,釋放鎖調(diào)用unlock()方法。如果對于每一個線程都需要加鎖和釋放鎖,性能會比較低。

(3)使用數(shù)據(jù)庫的樂觀鎖實現(xiàn)。

在用戶表上添加一個表示版本的字段。每次用戶登錄添加token時,都需要進行版本的比較,只有版本一致時,才進行添加token操作。

修改后的偽代碼如下:

User user = getUser(username,password);
if(null != user) {
    String token = findToken(user);
    if(null != token) {
    user.deleteToken(user);
        token = null;
    }
    if(null == token){
        int version = getUserVersion(user.getId());    
        if(version == user.getVersion()) { 
             updateVersion(version+1,User);
             user.insertNewToken(user);
         }else {
             throw new Exception("同一賬號不能同時登錄");
         }
    }
}else {
    throw new Exception("用戶不存在");
}

當(dāng)有兩個線程進入到if(null == token),第一個線程會修改版本號并插入token,而第二個線程則會因為版本號不一致,拋出異常。

參考文章:

https://blog.csdn.net/u014653...

https://blog.csdn.net/antony9...

文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/71246.html

相關(guān)文章

  • git實現(xiàn)github協(xié)同開發(fā)

    摘要:生成在控制臺中繼續(xù)輸入,生成密鑰。將文件夾中的公鑰添加到管理平臺中,在的個人賬戶的設(shè)置中找到如下界面。添加到暫存區(qū)后,我們會發(fā)現(xiàn)這兩個文件的顏色變?yōu)榱司G色。在熟悉以后,可能會發(fā)現(xiàn)有更加簡潔快速的提交修改的使用方法。在開發(fā)項目時,往往不是一個人進行項目開發(fā),而通常是以團隊的形式進行開發(fā)一個新功能,那項目開發(fā)是如何進行多人高效協(xié)作的呢?在不同的開發(fā)階段,我們遇到各種各樣的問題,當(dāng)遇到這些問題時,...

    Tecode 評論0 收藏0
  • vue微信網(wǎng)頁授權(quán)最終解決方案

    摘要:微信網(wǎng)頁授權(quán),基于適配方案,開發(fā)的微信授權(quán)方案。項目地址又又又一次來寫微信網(wǎng)頁授權(quán),一年前寫過的微信授權(quán)解決方案。 vue微信網(wǎng)頁授權(quán),基于vue-cli3.0+webpack 4+vant ui + sass+ rem適配方案+axios,開發(fā)的微信授權(quán)方案。項目地址:vue-wechat-auth 又又又一次來寫微信網(wǎng)頁授權(quán),一年前寫過的 [vue 微信授權(quán)解決方案]。 參考了[v...

    wawor4827 評論0 收藏0
  • 號外:友戶通支持企業(yè)自有用戶中心啦

    摘要:針對這種情況,友戶通特定開發(fā)了聯(lián)邦用戶中心來支持企業(yè)的自有用戶中心。友戶通支持通過協(xié)議使用企業(yè)內(nèi)部的支持協(xié)議的用戶中心賬號進行登錄。友戶通目前支持標(biāo)準(zhǔn)協(xié)議以及友戶通自定義協(xié)議可供企業(yè)集成。 友戶通做用友云的用戶系統(tǒng)也一年多了,經(jīng)常聽實施、售前等說要私有化部署友戶通,原因無非是企業(yè)的考慮到用戶安全性和單一用戶賬號的需求。但由于用戶管理的復(fù)雜性,友戶通部署與維護并不容易,因此經(jīng)常糾結(jié)在用戶...

    妤鋒シ 評論0 收藏0
  • JWT、OAuth 2.0、session 用戶授權(quán)實戰(zhàn)

    摘要:為用戶提供授權(quán)以允許用戶操作非公開資源,有很多種方式。具體的代碼根據(jù)不同的授權(quán)方案而有所不同。使用授權(quán)原理利用來驗證用戶,有兩種機制實現(xiàn)。使用來實現(xiàn)用戶授權(quán)主要用于簽發(fā)如果有將異步的簽名。注意這里的與之前用于簽發(fā)的應(yīng)該是同一個。 在很多應(yīng)用中,我們都需要向服務(wù)端提供自己的身份憑證來獲得訪問一些非公開資源的授權(quán)。比如在一個博客平臺,我們要修改自己的博客,那么服務(wù)端要求我們能夠證明 我是...

    Jochen 評論0 收藏0
  • 利用新浪API實現(xiàn)數(shù)據(jù)抓取微博數(shù)據(jù)爬取微博爬蟲

    摘要:本人長期出售超大量微博數(shù)據(jù)旅游網(wǎng)站評論數(shù)據(jù),并提供各種指定數(shù)據(jù)爬取服務(wù),。如果用戶傳入偽造的,則新浪微博會返回一個錯誤。 PS:(本人長期出售超大量微博數(shù)據(jù)、旅游網(wǎng)站評論數(shù)據(jù),并提供各種指定數(shù)據(jù)爬取服務(wù),Message to [email protected]。由于微博接口更新后限制增大,這個代碼已經(jīng)不能用來爬數(shù)據(jù)了。如果只是為了收集數(shù)據(jù)可以咨詢我的郵箱,如果是為了學(xué)習(xí)爬蟲,...

    liuyix 評論0 收藏0

發(fā)表評論

0條評論

最新活動
閱讀需要支付1元查看
<