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");

    }    

  • 相关阅读:
    linux sed 命令,sed -i
    linux子系统的初始化_subsys_initcall()
    jsp动作之 getProperty
    jsp动作之 setProperty
    eclipse jsp:useBean搞死人了。
    JSP中scope属性 scope属性决定了JavaBean对象存在的范围
    [转]mysql日常工作手记
    [转]mysql-mmm集群(多实例)
    Lua脚本语言入门学习其应用教程
    15分钟入门lua
  • 原文地址:https://www.cnblogs.com/chinaifae/p/10188897.html
Copyright © 2011-2022 走看看