.Net 如何限制用户登录的方法

时间:2021-05-28

名词解析
1.Cookies 按照英文单词翻译过来是“甜点”的意思。这个和我们计算机貌似没有什么关系。我们这里说的Cookies是指服务器在暂存在计算机上的一段资料。

2.Session 按照英文单词翻译过来是“会话”的意思。存在于服务器的内存中。

限制用户登录的一下场景
1。比如QQ 我们在一处登录QQ之后。如果我们在另一台电脑上再次登录这个时候就会被踢下线

2。我使用的邮箱也有上面情况

这样做在很大的程度上面保证了。账号的安全。

怎么样实现
方法1 : 在用户登录时将用户登录状态记录数据库中,每次登录时我们在数据库中查找用户是否登录。如果已经登录,做出相关的业务处理
方法2: 把用户登录状态的存在Session中
方法1明显有一个缺点,假设在服务器突然断电的情况下。是不是就悲剧了。这个已经登录的用户的状态就会乱,直接将导致用户无法再次登录所以我们这里选在Cookies 和Session 来实现这个场景

示例代码

复制代码 代码如下:
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
{
//如果用户没有登录
}


}

希望上面简单的代码对大家有帮助

声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。

相关文章