多端登錄如何實(shí)現(xiàn)踢人下線需求實(shí)現(xiàn)
1:項(xiàng)目背景
一個(gè)項(xiàng)目往往會有小程序,APP,PC等多端訪問,比如淘寶,京東等。這時(shí)候就會有一些踢人下線的需求,比如你在一臺電腦登錄了PC端,這時(shí)候你再另外一臺電腦也登錄PC端,這時(shí)候之前在另外一臺電腦上就會被強(qiáng)制下線。
或者你登錄了PC端,這時(shí)候你登陸了APP或者小程序,這時(shí)候PC端的賬號也會被強(qiáng)制下線
2:項(xiàng)目只有PC端
假設(shè)我們現(xiàn)在的項(xiàng)目只有PC端,沒有小程序或者APP,那么這時(shí)候就是很簡單了,用戶的sessin(也就是所謂的Token)一般都是存儲在redis中,session中包括用戶ID等一些信息,當(dāng)然還有一個(gè)最重要的就是登錄的ip地址。

1:用戶在登錄的時(shí)候,從redis中獲取用戶session,如果沒有就可以直接登錄了
2:用戶在另外一臺電腦登錄,從redis中獲取到用戶session,這時(shí)候用戶session是有的,說明用戶之前已經(jīng)登錄過了
3:這時(shí)候從用戶session中獲取IP,判斷二者的ip是不是相同,如果不同,這時(shí)候就要發(fā)送一個(gè)通知給客戶端,讓另外一臺設(shè)備登錄的賬號強(qiáng)制下線即可
3:項(xiàng)目有PC端和APP端和小程序端
當(dāng)你的應(yīng)用有PC端和APP端的時(shí)候,我們用戶的session如果還是只存一個(gè)ip地址,那明顯就是不夠的,因?yàn)楹芏嗲闆r下,我們PC端和APP端是可以同時(shí)登錄的,比如淘寶,京東等都是,也就是所謂的雙端登錄
這時(shí)候就會有多種情況
單端登錄:PC端,APP端,小程序只能有一端登錄
雙端登錄:允許其中二個(gè)端登錄
三端登錄:三個(gè)端都可以同時(shí)登錄
對于三端可以同時(shí)登錄就很簡單,但是現(xiàn)在有個(gè)限制,就是app端只能登錄一次,不能同時(shí)登錄,也就是我一個(gè)手機(jī)登錄了APP,另外一個(gè)手機(jī)登錄的話,之前登錄的APP端就要強(qiáng)制下線
所以我們的用戶session存儲的格式如下
{
userId:用戶的id
clientType:PC端,小程序端,APP端
imei:就是設(shè)備的唯一編號(對于PC端這個(gè)值就是ip地址,其余的就是手機(jī)設(shè)備的一個(gè)唯一編號)
}單端登錄
首先我們要知道,用戶登錄不同的設(shè)備那么用戶session是不一樣的。對于單端登錄,那么我們可以拿到用戶的所有的session,然后根據(jù)clientType和imei號來強(qiáng)制將其它端的用戶session刪除掉,然后通知客戶端強(qiáng)制下線
雙端登錄
同樣拿到所有用戶的session,然后根據(jù)自己的業(yè)務(wù)需求來判定哪一端需要強(qiáng)制下線,比如我們現(xiàn)在已經(jīng)登錄了PC端和APP端,這時(shí)候登錄小程序,現(xiàn)在要讓APP端的強(qiáng)制下線。
這時(shí)候登錄之后獲取用戶所有的session,這時(shí)候會有二個(gè)用戶session,首先拿到clientType = APP的session,然后來通知客戶端這個(gè)端需要強(qiáng)制下線。
如果這時(shí)候我登錄了PC端和一個(gè)APP端,這時(shí)候我用另外一臺手機(jī)登錄APP端,那么之前那臺手機(jī)上登錄的APP端就要被強(qiáng)制下線,這個(gè)時(shí)候僅通過clientType是不行的,因?yàn)槲叶€(gè)手機(jī)登錄的clientType都是APP端。所以這時(shí)候就要根據(jù)imei號來判斷了。因?yàn)椴煌氖謾C(jī)imei號是不一樣的。
這時(shí)候我拿到用戶所有的session
PC端的session
sessionA{
userId: 1,
clientType: PC,
imei: "123"
}
APP端的session
sessionA{
userId: 1,
clientType: APP,
imei: "12345"
}這時(shí)候我從另外一臺手機(jī)登錄的時(shí)候,生成的session應(yīng)該是這樣的
APP端的session
sessionA{
userId: 1,
clientType: APP,
imei: "1234567"
}
我發(fā)現(xiàn)同一個(gè)clientType的session已經(jīng)有了,這時(shí)候我要判斷imei號是否一樣,imei一樣說明是同一臺設(shè)備,不同說明不是同一臺設(shè)備,我們只需要把對應(yīng)設(shè)備的賬號強(qiáng)制下線即可了
總結(jié)
不管是單端登錄,雙端登錄還是多端登錄,我們都是根據(jù)用戶session來判斷。只要根據(jù)clientType和imei號來就可以滿足我們大部分的踢人下線需求了。
以上就是多端登錄如何實(shí)現(xiàn)踢人下線需求實(shí)現(xiàn)的詳細(xì)內(nèi)容,更多關(guān)于多端登錄踢人下線的資料請關(guān)注腳本之家其它相關(guān)文章!
相關(guān)文章
編寫高質(zhì)量代碼的30條黃金守則(首選隱式類型轉(zhuǎn)換)
這篇文章主要介紹了編寫高質(zhì)量代碼的30條黃金守則(首選隱式類型轉(zhuǎn)換),本文通過實(shí)例代碼給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-08-08
在IDEA(2020.2)中配置Git及使用Git的圖文詳解
這篇文章主要介紹了在IDEA(2020.2)中配置Git及使用Git的圖文詳解,本文通過圖文并茂的形式給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-12-12
安全校驗(yàn)Session驗(yàn)證碼并避免繞開驗(yàn)證碼攻擊
校驗(yàn)驗(yàn)證碼的Session是否為空或者校驗(yàn)用戶輸入的驗(yàn)證碼是否合法,構(gòu)造安全表單的關(guān)鍵就是永遠(yuǎn)不要相信用戶的輸入2012-01-01

