关于用户限制登录次数的问题

黑兔子 2014-12-26 02:40:58
怎么限制用户用同一账号登录2次?打开2次窗口?同一浏览器,我试过用session可以,但是不同浏览器的话session不行。求帮忙?
...全文
525 16 打赏 收藏 转发到动态 举报
写回复
用AI写文章
16 条回复
切换为时间正序
请发表友善的回复…
发表回复
bcsflilong 2015-01-01
  • 打赏
  • 举报
回复
引用 15 楼 skyhitnow 的回复:
[quote=引用 14 楼 bcsflilong 的回复:] [quote=引用 10 楼 zhouren1314 的回复:] [quote=引用 9 楼 MrsFeng 的回复:] [quote=引用 8 楼 zhouren1314 的回复:] [quote=引用 7 楼 bcsflilong 的回复:] 说 用session 的 那不是在扯淡吗? session 的作用域 是什么? 把登陆信息放到application的这种方式才是正解,可以在application中 方一个map key 为用户名 value 为累计登录数, 具体的逻辑需要自己好好在想想 但是这种方式是没问题的
1.信息量不是很大,又不是经常改动,建议放在application中 2.也可以用缓存啊,缓存技术挺多的[/quote] 还要考虑负载均衡[/quote] 均衡的话, 那就只有写进数据库了,不然怎么办,有何高见?[/quote]既然是负载均衡 还是放在库里处理吧,但是用户量大的话 数据库要遭罪了 或者考虑一下单独处理这块的缓存 尽量减少对库的读写[/quote] 一般验证是统一验证吧。逻辑写在验证服务器上就可以了吧。重复登录需要重复验证,验证时查看是否已经登录就可以了。[/quote]验证的时候需要读取数据库吧。
skyhitnow 2015-01-01
  • 打赏
  • 举报
回复
引用 14 楼 bcsflilong 的回复:
[quote=引用 10 楼 zhouren1314 的回复:] [quote=引用 9 楼 MrsFeng 的回复:] [quote=引用 8 楼 zhouren1314 的回复:] [quote=引用 7 楼 bcsflilong 的回复:] 说 用session 的 那不是在扯淡吗? session 的作用域 是什么? 把登陆信息放到application的这种方式才是正解,可以在application中 方一个map key 为用户名 value 为累计登录数, 具体的逻辑需要自己好好在想想 但是这种方式是没问题的
1.信息量不是很大,又不是经常改动,建议放在application中 2.也可以用缓存啊,缓存技术挺多的[/quote] 还要考虑负载均衡[/quote] 均衡的话, 那就只有写进数据库了,不然怎么办,有何高见?[/quote]既然是负载均衡 还是放在库里处理吧,但是用户量大的话 数据库要遭罪了 或者考虑一下单独处理这块的缓存 尽量减少对库的读写[/quote] 一般验证是统一验证吧。逻辑写在验证服务器上就可以了吧。重复登录需要重复验证,验证时查看是否已经登录就可以了。
bcsflilong 2014-12-30
  • 打赏
  • 举报
回复
引用 10 楼 zhouren1314 的回复:
[quote=引用 9 楼 MrsFeng 的回复:] [quote=引用 8 楼 zhouren1314 的回复:] [quote=引用 7 楼 bcsflilong 的回复:] 说 用session 的 那不是在扯淡吗? session 的作用域 是什么? 把登陆信息放到application的这种方式才是正解,可以在application中 方一个map key 为用户名 value 为累计登录数, 具体的逻辑需要自己好好在想想 但是这种方式是没问题的
1.信息量不是很大,又不是经常改动,建议放在application中 2.也可以用缓存啊,缓存技术挺多的[/quote] 还要考虑负载均衡[/quote] 均衡的话, 那就只有写进数据库了,不然怎么办,有何高见?[/quote]既然是负载均衡 还是放在库里处理吧,但是用户量大的话 数据库要遭罪了 或者考虑一下单独处理这块的缓存 尽量减少对库的读写
乔不思 2014-12-30
  • 打赏
  • 举报
回复
引用 12 楼 zhengweijian15 的回复:
数据库行级锁?
何解?
  • 打赏
  • 举报
回复
数据库行级锁?
wangzhuoyan 2014-12-30
  • 打赏
  • 举报
回复
这个话题,始终都不是绝对完美的办法,无论从应用,还是数据库都有弊端
乔不思 2014-12-30
  • 打赏
  • 举报
回复
引用 9 楼 MrsFeng 的回复:
[quote=引用 8 楼 zhouren1314 的回复:] [quote=引用 7 楼 bcsflilong 的回复:] 说 用session 的 那不是在扯淡吗? session 的作用域 是什么? 把登陆信息放到application的这种方式才是正解,可以在application中 方一个map key 为用户名 value 为累计登录数, 具体的逻辑需要自己好好在想想 但是这种方式是没问题的
1.信息量不是很大,又不是经常改动,建议放在application中 2.也可以用缓存啊,缓存技术挺多的[/quote] 还要考虑负载均衡[/quote] 均衡的话, 那就只有写进数据库了,不然怎么办,有何高见?
你好毒你好毒 2014-12-30
  • 打赏
  • 举报
回复
引用 8 楼 zhouren1314 的回复:
[quote=引用 7 楼 bcsflilong 的回复:] 说 用session 的 那不是在扯淡吗? session 的作用域 是什么? 把登陆信息放到application的这种方式才是正解,可以在application中 方一个map key 为用户名 value 为累计登录数, 具体的逻辑需要自己好好在想想 但是这种方式是没问题的
1.信息量不是很大,又不是经常改动,建议放在application中 2.也可以用缓存啊,缓存技术挺多的[/quote] 还要考虑负载均衡
乔不思 2014-12-30
  • 打赏
  • 举报
回复
引用 7 楼 bcsflilong 的回复:
说 用session 的 那不是在扯淡吗? session 的作用域 是什么? 把登陆信息放到application的这种方式才是正解,可以在application中 方一个map key 为用户名 value 为累计登录数, 具体的逻辑需要自己好好在想想 但是这种方式是没问题的
1.信息量不是很大,又不是经常改动,建议放在application中 2.也可以用缓存啊,缓存技术挺多的
bcsflilong 2014-12-28
  • 打赏
  • 举报
回复
说 用session 的 那不是在扯淡吗? session 的作用域 是什么? 把登陆信息放到application的这种方式才是正解,可以在application中 方一个map key 为用户名 value 为累计登录数, 具体的逻辑需要自己好好在想想 但是这种方式是没问题的
于金龙 2014-12-27
  • 打赏
  • 举报
回复
引用 5 楼 skyhitnow 的回复:
登录的时候会验证嘛,登录后的session中保存了用户的标志性信息,比如用户名/id之类,登录验证的时候根据此类信息查找session,找到了就是已经登录。将原session失效就好了
楼上正解。如果数据量不大的话,你可以建个map,key为user_id,value为session_id,用户登录验证通过的话,你就看看user_id是否在map中嘛......
skyhitnow 2014-12-26
  • 打赏
  • 举报
回复
登录的时候会验证嘛,登录后的session中保存了用户的标志性信息,比如用户名/id之类,登录验证的时候根据此类信息查找session,找到了就是已经登录。将原session失效就好了
小老头头 2014-12-26
  • 打赏
  • 举报
回复
把登陆信息放到application里面啊,服务器不关闭application会一直保存登陆的用户信息,注销的时候从application销毁就可以了
黑兔子 2014-12-26
  • 打赏
  • 举报
回复
引用 2 楼 xup8888 的回复:
不同浏览器,只能通过数据库记录登录状态,判断是否重复登录
这个可以考虑下,但是还要考虑很多因素,领导应该是不同意了!
小小2050 2014-12-26
  • 打赏
  • 举报
回复
不同浏览器,只能通过数据库记录登录状态,判断是否重复登录
暴龙神 2014-12-26
  • 打赏
  • 举报
回复
换电脑了,原来电脑没有退出,让登录么?
Re: 《用户管理及用户信息查询命令》 ---------------------------------------内容提要: 01/19)命令useradd   :创建用户02/19)命令usermod :修改用户信息03/19)命令userdel    :删除用户04/19)命令groupadd:创建新组05/19)命令groupdel :删除用户组06/19)命令passwd    :修改用户密码07/19)命令chage      :修改用户密码有效期08/19)命令chpasswd:批量更新用户密码09/19)命令su            :切换用户10/19)命令visudo     :编辑sudoers文件11/19)命令sudo        :以另一个用户身份执行命令12/19)命令id             :显示用户用户组的信息13/19)命令w             :显示已登录用户信息14/19)命令who          : 显示已登录用户信息15/19)命令users       :显示已登录用户16/19)命令whoami    : 显示当前登录用户名17/19)命令last          :显示用户登录列表18/19)命令lastb         : 显示用户登录失败的记录19/19)命令lastlog      : 显示所有用户的最近登录记录  本人在教学和实战过程中发现,即便是有一定运维经验的人,可能已经能够搭建一定复杂度的Linux架构,但是在来来回回的具体操作中,还是体现出CLI(命令界面)功底不够扎实,甚至操作的非常‘拙’、处处露‘怯’。 对一个士兵来说,枪就是他的武器,对于一个程序员来说,各种library(工具库)就是他的武器;而对于Linux运维人员来说,无疑命令行工具CLI(命令界面)就是他们的武器;高手和小白之间的差距往往就体现在对于这些“武器”的掌握和熟练程度上。有时候一个参数就能够解决的事情,小白们可能要写一个复杂的Shell脚本才能搞定,这就是对CLI(命令界面)没有理解参悟透彻导致。 研磨每一个命令就是擦拭手中的作战武器,平时不保养不理解,等到作战的时候,一定不能够将手中的武器发挥到最好,所以我们要平心、静气和专注,甘坐冷板凳一段时间,才能练就一身非凡的内功! 本教程从实战出发,结合当下流行或最新的Linux(v6/7/8 版本)同时演示,将命令行结合到解决企业实战问题中来,体现出教学注重实战的务实精神,希望从事或未来从事运维的同学,能够认真仔细的学完Linux核心命令的整套课程。 本课程系列将逐步推出,看看我教学的进度和您学习的步伐,孰占鳌头! 注:关于教学环境搭建,可以参考本人其它课程系列,本教学中就不再赘述! 《参透 VMware 桌面级虚拟化》 《在虚拟机中安装模版机(包括应用软件等)》 《SecureCRT 连接 GNS3/Linux 的安全精密工具》 

81,091

社区成员

发帖
与我相关
我的任务
社区描述
Java Web 开发
社区管理员
  • Web 开发社区
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧