.Net 如何限制用戶登錄
名詞解析
1.Cookies 按照英文單詞翻譯過來是“甜點”的意思。這個和我們計算機(jī)貌似沒有什么關(guān)系。我們這里說的Cookies是指服務(wù)器在暫存在計算機(jī)上的一段資料。
2.Session 按照英文單詞翻譯過來是“會話”的意思。存在于服務(wù)器的內(nèi)存中。
限制用戶登錄的一下場景
1。比如QQ 我們在一處登錄QQ之后。如果我們在另一臺電腦上再次登錄這個時候就會被踢下線
2。我使用的郵箱也有上面情況
這樣做在很大的程度上面保證了。賬號的安全。
怎么樣實現(xiàn)
方法1 : 在用戶登錄時將用戶登錄狀態(tài)記錄數(shù)據(jù)庫中,每次登錄時我們在數(shù)據(jù)庫中查找用戶是否登錄。如果已經(jīng)登錄,做出相關(guān)的業(yè)務(wù)處理
方法2: 把用戶登錄狀態(tài)的存在Session中
方法1明顯有一個缺點,假設(shè)在服務(wù)器突然斷電的情況下。是不是就悲劇了。這個已經(jīng)登錄的用戶的狀態(tài)就會亂,直接將導(dǎo)致用戶無法再次登錄所以我們這里選在Cookies 和Session 來實現(xiàn)這個場景
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
{
//如果用戶沒有登錄
}
}