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

Sa-Token不同模式實(shí)現(xiàn)單地登錄?多地登錄?同端互斥登錄

 更新時(shí)間:2023年07月18日 10:42:49   作者:省長(zhǎng)[機(jī)智]  
這篇文章主要為大家介紹了Sa-Token不同模式實(shí)現(xiàn)單地登錄?多地登錄?同端互斥登錄,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪

一、需求分析

如果你經(jīng)常使用騰訊QQ,就會(huì)發(fā)現(xiàn)它的登錄有如下特點(diǎn):它可以手機(jī)電腦同時(shí)在線,但是不能在兩個(gè)手機(jī)上同時(shí)登錄一個(gè)賬號(hào)。

同端互斥登錄,指的就是:像騰訊QQ一樣,在同一類(lèi)型設(shè)備上只允許單地點(diǎn)登錄,在不同類(lèi)型設(shè)備上允許同時(shí)在線。

動(dòng)態(tài)演示圖:

 Sa-Token 是一個(gè)輕量級(jí) java 權(quán)限認(rèn)證框架,主要解決登錄認(rèn)證、權(quán)限認(rèn)證、單點(diǎn)登錄、OAuth2、微服務(wù)網(wǎng)關(guān)鑒權(quán) 等一系列權(quán)限相關(guān)問(wèn)題。

Gitee 開(kāi)源地址:https://gitee.com/dromara/sa-token

本文將介紹在 Sa-Token 中,如何實(shí)現(xiàn)以下登錄策略:

  • 單地登錄:指一個(gè)賬號(hào)同一時(shí)間只能在一個(gè)地方登錄,新登錄會(huì)擠掉舊登錄,也可以叫:?jiǎn)味说卿洝?/li>
  • 多地登錄:指一個(gè)賬號(hào)同一時(shí)間可以在不同地方登錄,新登錄會(huì)和舊登錄共存,也可以叫:多端登錄。
  • 同端互斥登錄:在同一類(lèi)型設(shè)備上只允許單地點(diǎn)登錄,在不同類(lèi)型設(shè)備上允許同時(shí)在線,參考騰訊QQ的登錄模式:手機(jī)和電腦可以同時(shí)在線,但不能兩個(gè)手機(jī)同時(shí)在線。

與之對(duì)應(yīng)的,注銷(xiāo)策略也將分為以下幾種:

  • 單端注銷(xiāo):只在調(diào)用退出的一端注銷(xiāo)。
  • 全端注銷(xiāo):一端注銷(xiāo),全端下線。
  • 同端注銷(xiāo):例如將所有手機(jī)端注銷(xiāo)下線,PC端不受影響。

二、多地登錄

此模式較為簡(jiǎn)單,Sa-Token 默認(rèn)模式即為多地登錄模式。

1、首先引入 Sa-Token 依賴(lài):

<!-- Sa-Token 權(quán)限認(rèn)證 -->
<dependency>
    <groupId>cn.dev33</groupId>
    <artifactId>sa-token-spring-boot-starter</artifactId>
    <version>1.34.0</version>
</dependency>

注:如果你使用的是 SpringBoot 3.x,只需要將 sa-token-spring-boot-starter 修改為 sa-token-spring-boot3-starter 即可。

2、在用戶(hù)登錄時(shí)將賬號(hào)id寫(xiě)入會(huì)話中

@RestController
@RequestMapping("/user/")
public class UserController {
    @RequestMapping("doLogin")
    public SaResult doLogin(String username, String password) {
        // 此處僅作示例模擬,真實(shí)項(xiàng)目需要從數(shù)據(jù)庫(kù)中查詢(xún)數(shù)據(jù)進(jìn)行比對(duì) 
        if("zhang".equals(username) && "123456".equals(password)) {
            StpUtil.login(10001);
            return SaResult.ok("登錄成功");
        }
        return SaResult.ok("登錄失敗");
    }
}

啟動(dòng)類(lèi):

@SpringBootApplication
public class SaTokenDemoApplication {
    public static void main(String[] args) {
        SpringApplication.run(SaTokenDemoApplication.class, args); 
        System.out.println("\n啟動(dòng)成功:Sa-Roken 配置如下:" + SaManager.getConfig());
    }
}

如上代碼,在多人登錄同一賬號(hào)時(shí)將不會(huì)對(duì)舊會(huì)話做任何處理,同一賬號(hào)可以在多個(gè)地點(diǎn)任意登錄,互不影響。

3、如果要全端注銷(xiāo),可以調(diào)用 logout 方法:

// 會(huì)話注銷(xiāo)
@RequestMapping("logout")
public SaResult logout() {
    StpUtil.logout();
    return SaResult.ok("退出登錄成功");
}

調(diào)用如上方法注銷(xiāo)后,當(dāng)前賬號(hào)所有端將一起下線。

4、單端注銷(xiāo)

如果要只注銷(xiāo)一端,可將配置文件中 is-share 的值配置為 false

sa-token:
    is-share: false

此配置項(xiàng)的含義為:在多人登錄同一賬號(hào)時(shí),是否共用一個(gè) Token。

  • 為 true 時(shí):所有登錄共用一個(gè) Token。
  • 為 false 時(shí):每次登錄新建一個(gè) Token。

此值為 false 后,每次登錄都將返回不同的 Token,與之對(duì)應(yīng)的,調(diào)用 StpUtil.logout() 也只會(huì)注銷(xiāo)掉當(dāng)前的 Token,其他端不受影響。

三、單地登錄

單地登錄的重點(diǎn)是需要改一下 yml 配置文件:

sa-token: 
    is-concurrent: false

is-concurrent 的含義為是否允許同一賬號(hào)并發(fā)登錄:

  • 為 true 時(shí):允許一起登錄。
  • 為 false 時(shí):新登錄擠掉舊登錄。

其它代碼與 [多地登錄](méi) 無(wú)異,當(dāng)我們?cè)趦蓚€(gè)瀏覽器分別登錄同一賬號(hào)時(shí),舊會(huì)話再次訪問(wèn)系統(tǒng)將會(huì)得到如下提示:

{
    "code": 401,
    "msg": "Token 已被頂下線",
    "data": null
}

在 單地登錄 模式中,不存在注銷(xiāo)策略的問(wèn)題,因?yàn)橥粫r(shí)間內(nèi),一個(gè)賬號(hào)最多在一個(gè)設(shè)備在線,只要調(diào)用注銷(xiāo),就必然是全端下線。

四、同端互斥登錄

好了,終于輪到主角出場(chǎng),同端互斥登錄可以讓我們像騰訊QQ一樣,在同一類(lèi)型設(shè)備上只允許單地點(diǎn)登錄,在不同類(lèi)型設(shè)備上允許同時(shí)在線。

那么在 Sa-Token 中如何做到同端互斥登錄呢?

首先如 單地登錄一樣,在配置文件中,將 sa-token.is-concurrent 配置為false,然后調(diào)用登錄等相關(guān)接口時(shí)聲明設(shè)備標(biāo)識(shí)即可:

1、指定設(shè)備標(biāo)識(shí)登錄

StpUtil.login(10001, "PC");

調(diào)用此方法登錄后,同設(shè)備的會(huì)被頂下線(不同設(shè)備不受影響),再次訪問(wèn)系統(tǒng)時(shí)會(huì)拋出 NotLoginException 異常,場(chǎng)景值=-4

場(chǎng)景值對(duì)應(yīng)常量含義說(shuō)明
-1NotLoginException.NOT_TOKEN未能從請(qǐng)求中讀取到 Token
-2NotLoginException.INVALID_TOKEN已讀取到 Token,但是 Token無(wú)效
-3NotLoginException.TOKEN_TIMEOUT已讀取到 Token,但是 Token已經(jīng)過(guò)期
-4NotLoginException.BE_REPLACED已讀取到 Token,但是 Token 已被頂下線
-5NotLoginException.KICK_OUT已讀取到 Token,但是 Token 已被踢下線

如果第二個(gè)參數(shù)填寫(xiě)null或不填,代表將這個(gè)賬號(hào)id所有在線端踢下線,被踢出者再次訪問(wèn)系統(tǒng)時(shí)會(huì)拋出 NotLoginException 異常,場(chǎng)景值=-5

2、查詢(xún)當(dāng)前登錄的設(shè)備標(biāo)識(shí)

StpUtil.getLoginDevice();

如果在登錄時(shí)未指定設(shè)備類(lèi)型值,調(diào)用此方法將返回默認(rèn)值:default-device

3、指定設(shè)備端類(lèi)型下線

業(yè)務(wù)場(chǎng)景舉例:在手機(jī)端控制PC端下線(手機(jī)端本身不受影響)

StpUtil.logout(10001, "PC");

4、全端下線

在調(diào)用 logout 方法時(shí),不填寫(xiě)具體的設(shè)備端類(lèi)型,將默認(rèn)控制所有端一起下線。

StpUtil.logout(10001);

以上就是 Sa-Token 框架在處理登錄問(wèn)題時(shí)的各種方案,可以看出不管是簡(jiǎn)單的多地登錄還是復(fù)雜的同端互斥登錄,在 Sa-Token 都有完善的解決方案。

參考資料

以上就是Sa-Token不同模式實(shí)現(xiàn)單地登錄 多地登錄 同端互斥登錄的詳細(xì)內(nèi)容,更多關(guān)于Sa-Token登錄模式的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!

相關(guān)文章

最新評(píng)論