zoukankan      html  css  js  c++  java
  • java接口如何有效防止恶意请求

    java接口如何有效防止恶意请求?已解决

     

    解决方法:

    1.在redis数据库db0中新建一个名为rd_sms_request_count表,表结构:

    Ip:客户请求的ip

    Success_count:成功次数

    Failure_count:失败次数

    Is_close:是否已经加入到防火墙黑名单,1是  0否 ,默认0

    2.结合业务,判单哪个ip是恶意的,每当一个ip访问接口,按照代码返回码,如果是都是错误请求,添加到redis数据库中的Failure_count字段加1,如果都是返回正确结果,那么Success_count加1,Java后台启动一个线程,每天统计一次rd_sms_request_count,先删除rd_sms_request_coun表的Success_count大于0的记录,证明这个ip是正常用户;如果Success_count等于0而且Failure_count大于10000(规则可自定义)就通过java代码把这个ip加入到iptables黑名单中,加入到iptables黑名单中的记录设置为1。

    3.把满足条件的ip加入到iptables黑名单中核心代码(在linux测试过可以)

    String[] cmd = new String[] { "/bin/sh", "-c", "iptables -I INPUT -s 211.1.0.24 -j DROP;iptables -I INPUT -s 211.1.0.25 -j

    DROP" };

            try {

            Runtime.getRuntime().exec(cmd);

           } catch (Exception e) {

               e.printStackTrace();

           }finally {

           Runtime.getRuntime().exec("service iptables save");

    }    

  • 相关阅读:
    MFC加载图片
    动态数组类
    MFC程序打包方法
    如何在C++中使用动态三维数组
    Ansys热应力计算
    像使用数据库一样使用xml
    过年回家的一点感想
    前后端框架和设计模式
    国外支付PayPal
    可重用的管理后台代码
  • 原文地址:https://www.cnblogs.com/chinaifae/p/10188897.html
Copyright © 2011-2022 走看看