php - pc端 限制用户登陆次数!
怪我咯
怪我咯 2017-05-31 10:33:27
0
4
854

我是将登陆的错误次数和时间存到session,当达到最大错误次数时将无法登录,可是将cookie清空后仍然可以登录。请问应该怎么解决?或者有其它的方式限制登录次数吗?谢谢!

怪我咯
怪我咯

走同样的路,发现不同的人生

全部回复(4)
我想大声告诉你

数据库加个字段,超过次数锁定账户...

给我你的怀抱

用memcache 或者 redis 做缓存控制

$key = 登录账户

$value = 登录失败次数

$this->set($key,$value);

小葫芦

用ip和HTTP_USER_AGENT 来判断是否同一用户

小葫芦

像你这种情况,只能通过全局缓存来处理了。如果你要控制某用户名的登录次数,那么就
1.针对keyvalue缓存
统一数据结构key=value => 用户名={'登录次数':1},接下来无论用redis、memcache、mysql(建cache表,列[key value],索引hash key)
直接$userinfo = $cacheobj->get('用户名')获取用户信息,判断登录次数,自增登录次数后$cacheobj->set('用户名', $userinfo)回写

2.纳入到数据库登录信息表结构
给mysql用户登录表新增登录次数列,然后就是调用sql,获取,判断,自增,更新就欧了

如果要含时间纬度,那么

1.针对keyvalue缓存
数据结构更新为用户名={'登录次数':1, '超时时间':时间戳},判断再加时间纬度的判断,超时将登录次数置为0

2.针对非mysql的keyvalue缓存(redis、memcache)
直接$cacheobj->set('用户名', '登录次数', 超时时间)

3.纳入到数据库登录信息表结构
这样子的话就再加一列超时时间

实现的方法无数种,主要看实际场景和资源。

热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板