.Net 如何限制用戶登錄
名詞解析
1.Cookies 按照英文單詞翻譯過(guò)來(lái)是“甜點(diǎn)”的意思。這個(gè)和我們計(jì)算機(jī)貌似沒(méi)有什么關(guān)系。我們這里說(shuō)的Cookies是指服務(wù)器在暫存在計(jì)算機(jī)上的一段資料。
2.Session 按照英文單詞翻譯過(guò)來(lái)是“會(huì)話”的意思。存在于服務(wù)器的內(nèi)存中。
限制用戶登錄的一下場(chǎng)景
1。比如QQ 我們?cè)谝惶幍卿決Q之后。如果我們?cè)诹硪慌_(tái)電腦上再次登錄這個(gè)時(shí)候就會(huì)被踢下線
2。我使用的郵箱也有上面情況
這樣做在很大的程度上面保證了。賬號(hào)的安全。
怎么樣實(shí)現(xiàn)
方法1 : 在用戶登錄時(shí)將用戶登錄狀態(tài)記錄數(shù)據(jù)庫(kù)中,每次登錄時(shí)我們?cè)跀?shù)據(jù)庫(kù)中查找用戶是否登錄。如果已經(jīng)登錄,做出相關(guān)的業(yè)務(wù)處理
方法2: 把用戶登錄狀態(tài)的存在Session中
方法1明顯有一個(gè)缺點(diǎn),假設(shè)在服務(wù)器突然斷電的情況下。是不是就悲劇了。這個(gè)已經(jīng)登錄的用戶的狀態(tài)就會(huì)亂,直接將導(dǎo)致用戶無(wú)法再次登錄所以我們這里選在Cookies 和Session 來(lái)實(shí)現(xiàn)這個(gè)場(chǎng)景
if (Session["LOGIN_USER_LIST"] != null)
{
Dictionary<Guid,UserInfo> Userlist= Session["LOGIN_USER_LIST"] as Dictionary<Guid,UserInfo>;
Guid LoginKey =new Guid();
Guid.TryParse(CookieHelper.getCookie("LOG_USER_KEY"), out LoginKey);
if (Userlist.Keys.Contains(LoginKey))
{
//如何用戶登錄
}
else
{
//如果用戶沒(méi)有登錄
}
}