`

登录接口防攻击 02

    博客分类:
  • Java
阅读更多

可以参考前一篇博客:http://hw1287789687.iteye.com/blog/2215776

 

我们先考虑一种机器自动攻击的情形:

比如攻击者通过程序,每10秒钟访问登录接口,并且用户名和密码都一样,当然密码是错误的.

如何防止这种攻击呢?

方案一:

(1)登录失败,则开始计数;

(2)判断失败次数是否超过10(次数可以定制),若超过,则直接返回response code为401(无权访问)

,若没有超过,继续访问数据库进行登录验证,登录失败则失败次数加1

(3)登录失败,判断与之前登录失败的密码是否一致,若一致,则失败次数加1;若不一致,则执行(1);



 

 

那么有个问题:

判断失败次数是否超过10,则直接返回response code为401,万一修改了密码,原错误密码是正确的怎么办呢?

判断超过10次的基础上,再判断与上次登录相距多久,如果超过1个小时,则仍然查数据库

 

(4)若登录成功,则失败次数减1

 

 

注意:每个错误密码都对应自身失败的次数,而不是所有错误登录一起计算的.

前10次,还是会查询数据库.后面的登录(相同的错误密码)就不会查询数据库了,什么也不做直接设置response 的status为401.

 

为什么要处理?有人说就让它登录呗,反正密码是错误的,又登录不进去!

但是这些无效的请求依然会访问数据库,无谓地增加系统负担,所以必须要考虑应对方案.

 

方案二:

相同的错误密码,连续登录3次之后,后面的登录,直接匹配用户名和密码是否一致,若一致,则直接返回登录失败信息,不一致才真正访问数据库.

(a)登录失败,判断是否有该错误密码的记录,若有,则失败次数+1;若没有则增加记录,错误次数设置为1;

(b)判断失败次数是否超过3,超过则直接返回登录失败,不查询数据库;否则,查询数据库;

(c)若修改密码,则清除该用户所有的错误密码记录.

可以参考前一篇博客:http://hw1287789687.iteye.com/blog/2215776

  • 大小: 33.3 KB
  • 大小: 36.9 KB
3
1
分享到:
评论
4 楼 hw1287789687 2015-06-04  
czb20100314 写道
我有个问题请教下,如果黑客知道了最高权限用户名,然后故意输入十次错误密码,那到时候真正的管理员输入,怎么办?


黑客在错误登录10次之后,后面的登录就不会访问数据库了,这样就可以避免数据库频繁的无用访问了.
真正的管理员因为知道密码,所以登录的时候,没有匹配的错误密码,即失败登录次数为0.那么仍然会访问数据库进行验证,即可登录成功.
针对方案一的部分核心代码,使用redis
 /***
     * 登录失败
     *
     * @param account
     * @param pwd
     */
    private void loginFailed(String account, String pwd) {
        RedisHelper redisHelper = RedisHelper.getInstance();
        String oldPassword = redisHelper.getKeyCache(account, REDIS_KEY_FAILED_PWD);
//        Map map=redisHelper.getAllKeyCache(account);
        if (oldPassword == null || oldPassword.equals("")) {
            redisHelper.saveKeyCache(account, REDIS_KEY_FAILED_PWD, pwd);
            redisHelper.saveKeyCache(account, REDIS_KEY_FAILED_COUNT, "1");
        } else {//
            String failedAccount = redisHelper.getKeyCache(account, REDIS_KEY_FAILED_COUNT);
            if (pwd.equalsIgnoreCase(oldPassword)) {
                redisHelper.saveKeyCache(account, REDIS_KEY_FAILED_COUNT, String.valueOf(Integer.parseInt(failedAccount) + 1));
            } else {
                redisHelper.saveKeyCache(account, REDIS_KEY_FAILED_PWD, pwd);
                redisHelper.saveKeyCache(account, REDIS_KEY_FAILED_COUNT, "1");
            }
        }
    }

    /***
     * 登录成功
     *
     * @param account
     */
    private void loginSuccess(String account) {
        RedisHelper redisHelper = RedisHelper.getInstance();
        redisHelper.clearKeyCache(account, REDIS_KEY_FAILED_PWD);
        redisHelper.clearKeyCache(account, REDIS_KEY_FAILED_COUNT);
    }
3 楼 czb20100314 2015-06-04  
我有个问题请教下,如果黑客知道了最高权限用户名,然后故意输入十次错误密码,那到时候真正的管理员输入,怎么办?
2 楼 hw1287789687 2015-06-03  
wengcang 写道
你的计数不是放到数据库么?其次,个人觉得没有人会使用相同的密码一直访问你的系统的,黑客攻击肯定是遍历字典,这样,你系统无情中又多了处理逻辑,我们是失败2次增加验证码就可以了

计数放到redis中.
客户端登录接口因为考虑到后台登录,所以没有图形验证码
1 楼 wengcang 2015-06-03  
你的计数不是放到数据库么?其次,个人觉得没有人会使用相同的密码一直访问你的系统的,黑客攻击肯定是遍历字典,这样,你系统无情中又多了处理逻辑,我们是失败2次增加验证码就可以了

相关推荐

    API接口手工防御被恶意调用和接口被攻击

    通常情况下的api接口防护有如下几种: 使用HTTPS防止抓包,使用https至少会给破解者在抓包的时候提高一些难度 接口参数的加解密,通过md5加密数据+时间戳+随机字符串(salt),然后将MD5加密的数据和时间戳、原数据均...

    web安全措施.你写的WEB API接口如何预防黑客攻击_webservice接口实例

    记录API的调用日志,监控异常行为,如频繁失败的登录尝试或异常高的请求频率,以便及时发现并应对潜在攻击。 最后,**安全编码和训练** 是防御的前线。开发者应该遵循安全编码的最佳实践,了解常见的攻击模式,参加...

    API接口安全策略文档

    首先,针对伪装攻击,即第三方非法调用接口,我们可以通过严格的权限控制和身份验证机制来防止。API接口应只接受经过认证的应用程序的请求,这通常涉及到分配唯一的APP ID和Secret,使得服务端可以通过APP ID查找出...

    防攻击 易语言端口转发源码

    在“防攻击 易语言端口转发源码”这个主题中,我们将深入探讨易语言实现端口转发的基本原理、代码结构以及可能涉及到的相关知识点。 端口转发的核心原理是利用TCP或UDP协议栈的工作机制,监听本地的一个端口,当...

    C#winform工具模拟getpost请求,app防攻击加密源码

    2,写的接口总是被攻击的可以借鉴此加密方式。 【2】为啥要写这个 1,近期我们团队做的App接口被破解,老是被频繁调用,服务器致瘫; 2,想了办法加密了,如果遇到问题想调试,没办法通过日志里的请求串来直接调用;...

    网络工程交换机防攻击配置

    网络工程中的交换机防攻击配置是一项至关重要的任务,旨在保护网络设备和数据不受恶意攻击。本文将详细讲解如何在锐捷交换机上进行防攻击配置,包括防ARP攻击、端口安全配置、单臂路由、PPP验证以及生成树协议等关键...

    接口文档模板.docx

    - **防注入攻击**:防止SQL注入等安全漏洞。 6. **文档规范** - **清晰性**:参数说明要明确,避免模糊不清。 - **一致性**:所有接口的格式、命名和注释应保持一致。 - **更新维护**:接口发生变化时,文档需...

    预防溢出攻击

    压缩包中的"IT168.com-109493Safe3IF"可能是一个关于安全防护的资源或教程,它可能包含了更具体的预防溢出攻击的策略和技术,如3IF可能代表一种安全框架或接口。在实际应用中,结合这样的资源学习和实践,可以进一步...

    java AOP接口防刷代码

    在这个"java AOP接口防刷代码"中,我们很可能是找到了一种防止接口被恶意频繁调用的解决方案,这在Web应用中尤其重要,因为接口被刷可能会导致服务器资源耗尽,甚至影响正常用户的服务。 AOP的工作原理是通过动态...

    2023最新防红短链接在线生成源码内置接口无广告.zip

    防红短链接,全称“防止被红包钓鱼的短链接”,是一种用于保护用户免受恶意链接攻击的技术。2023年最新发布的这款防红短链接在线生成源码,以其内置接口和无广告的特点,为开发者提供了一个高效且安全的解决方案。 ...

    详解Java分布式IP限流和防止恶意IP攻击方案

    这种方案可以应用于分布式环境下接口调用频次管控和防止恶意IP攻击,保护系统和用户的安全。 四、扩展和优化 在实际应用中,可以根据业务需求进行扩展和优化,例如增加更多的规则和限制,提高防止恶意IP攻击的能力...

    网银最新接口,北京发布攻击通用

    【网银最新接口详解】 随着科技的发展,网银服务已经成为我们日常生活中不可或缺的一部分,而网银接口作为连接银行系统与用户的重要桥梁,其安全性、稳定性和便捷性至关重要。"网银最新接口"这一概念,指的是银行...

    DOS攻击介绍与防御

    2. **网络层次模型**:OSI七层模型(物理层、数据链路层、网络层、传输层、会话层、表示层、应用层)和TCP/IP四层模型(网络接口层、网络层、传输层、应用层)用于定义网络通信的各个阶段和功能。 3. **IP地址**:...

    SpringBoot系列——防重放与操作幂等.doc

    SpringBoot 防重放与操作幂等 在日常开发中,我们经常会遇到需要防止重复提交和操作幂等的问题,本文将记录 SpringBoot 实现简单防重放与幂等的方法。 防重放是指防止数据重复提交,例如用户多次点击提交按钮或...

    ARP 攻击 以及 防护 C++ 控制台 WinPcap_4

    1. 使用WinPcap库进行网络包捕获:WinPcap是一个开源的网络包捕获和网络分析库,允许程序访问网络接口的底层数据包。 2. 解析和构建ARP包:程序需要理解ARP协议的结构,能够读取和创建ARP包。 3. 发送和接收ARP包:...

    kk-anti-reptile开源反爬虫接口防刷组件 v1.0.zip

    《kk-anti-reptile开源反...总之,kk-anti-reptile开源反爬虫接口防刷组件 v1.0是一个强大的工具,它提供了多种策略来防御爬虫攻击,保护Web接口的安全。无论是学习还是实际应用,这个组件都值得我们深入研究和使用。

    锐捷交换机设备对网络攻击的防范

    为了对抗这些攻击,锐捷交换机内置了包括防SYN、Smurf攻击、DOS攻击、源IP地址欺骗攻击、检测源地址检查等多种防护措施。其中,BPDU Guard功能防止对生成树协议的攻击,而基于802.1x/RADIUS的身份验证、SSH、源IP...

    高并发场景下如何保证接口幂等性?综合比较了防重令牌(token)、随机字符串(noncestr)、幂等表、防重表、数据库唯一索引

    在高并发场景中,接口幂等性是一个至关重要的概念,它确保同一个请求无论被调用多少次,结果始终一致,避免出现重复操作导致的数据不一致问题。本文将深入探讨几种常见的幂等性实现策略,包括防重令牌(Token)、...

    XSS跨站脚本攻击剖析与防御

    - 3.7 "attackapi.pdf"可能介绍了攻击者如何利用API接口进行XSS攻击,这通常涉及未验证的用户输入和错误的数据处理。 - 6.4 "利用flash进行xss攻击剖析.pdf"可能讨论了Flash技术在XSS攻击中的角色,因为Flash曾经...

Global site tag (gtag.js) - Google Analytics