时间: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邮箱联系删除。
在你将现有的用户登录(SignIn)站点从ASP.NET迁移至ASP.NETCore时,你将面临这样一个问题——如何让ASP.NET与ASP.NETCore用户
ASP.NET身份认证基础在开始今天的内容之前,我想有二个最基础的问题首先要明确:1.如何判断当前请求是一个已登录用户发起的?2.如何获取当前登录用户的登录名?
几种常见的方法,本文主要内容包括: 第一部分:首先我们来说一下如何解决ASP.net中的文件上传大小限制的问题,我们知道在默认情况下ASP.NET的文件上
如何限制局域网网速控制网速的有效方法如何限制局域网网速控制网速的有效方法如何限制局域网网速控制网速的有效方法如何限制局域网网速控制网速的有效方法如何限制局域网网
本文实例讲述了laravel框架创建授权策略。分享给大家供大家参考,具体如下:用户只能编辑自己的资料在完成对未登录用户的限制之后,接下来我们要限制的是已登录用户