最新阿里需求挑战-十分钟内连续登录5次失败,需要等待30分钟才能登录【附图
来源:http://www.tudoupe.com时间:2022-03-05
前言
今天看到一个文章,‘阿里面试官问我:十分钟内连续登录5次失败,需要等待30分钟才能登录’,觉得很有意思,虽然是一个普遍需求,但是解决方案非常多,于是自己半个小时画了个图,写了几行伪代码,来解一下这个需求,毕竟天天CRUD也挺无聊的,非最佳解决方案,仅供互相讨论学习,希望各位轻喷。
直接上图

图解
- 登录请求
- 验证锁定缓存,锁定直接返回登录次数过多已锁定
- 未锁定 验证账号密码
- 验证失败 最近10分钟失败次数计数 次数>=5,设置锁定缓存,返回失败
- 验证成功 删除计数缓存,返回成功
代码实现
失败计数器(更新setCheckFailCounter方法)
第一版本代码
第一版本计数器的问题
时间滑动性的问题,比如10分钟内只失败了4次 然后又可以进行请求了,又来了一次验证失败的请求,这个请求与前面的后三次失败也在10分钟内,但是这时候失败总次数只是1,其实相对于最新的一次登录失败,十分钟内的失败次数也是4
新版本的解决思路
每分钟的操作失败进行单独的统计,每次用系统时间向前检查10分钟总共失败次数,大于5就进行锁定,做到了,解决了第一版本的问题,新版本的代码已经在上面更新了
总结
核心点在于每次都是最近10分钟的总失败次数,而不是失败了一次开始10分钟过期做自增,这也是自己再初版代码出现的问题,已经解决了
上一篇:快速设置自己的macbook
相关新闻
- 2022-08-04 WPF的由来
- 2022-08-04 Win11勒索软件防护怎么打开?Win11安
- 2022-08-04 Windows系统jdk的配置
- 2022-08-04 Windows10 OneNote怎么重新登录?如何重
- 2022-08-04 超好用的 Windows 效率工具推荐
- 2022-08-04 Windows如何在CMD或PowerShell中配置代理
- 2022-08-04 powershell和cmd对比
- 2022-08-04 【QT】Windows下QT下载安装
- 2022-08-04 windows下 C++ 实现类属性的get和set方
- 2022-08-04 Win11快速助手在哪里?Win11打开快速
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
