Java学习者论坛

 找回密码
 立即注册

QQ登录

只需一步,快速开始

手机号码,快捷登录

恭喜Java学习者论坛(https://www.javaxxz.com)已经为数万Java学习者服务超过8年了!积累会员资料超过10000G+
成为本站VIP会员,下载本站10000G+会员资源,购买链接:点击进入购买VIP会员
JAVA高级面试进阶视频教程Java架构师系统进阶VIP课程

分布式高可用全栈开发微服务教程

Go语言视频零基础入门到精通

Java架构师3期(课件+源码)

Java开发全终端实战租房项目视频教程

SpringBoot2.X入门到高级使用教程

大数据培训第六期全套视频教程

深度学习(CNN RNN GAN)算法原理

Java亿级流量电商系统视频教程

互联网架构师视频教程

年薪50万Spark2.0从入门到精通

年薪50万!人工智能学习路线教程

年薪50万!大数据从入门到精通学习路线年薪50万!机器学习入门到精通视频教程
仿小米商城类app和小程序视频教程深度学习数据分析基础到实战最新黑马javaEE2.1就业课程从 0到JVM实战高手教程 MySQL入门到精通教程
查看: 530|回复: 0

[servlet学习]利用Filter实现防止DOS攻击

[复制链接]
  • TA的每日心情
    开心
    2021-3-12 23:18
  • 签到天数: 2 天

    [LV.1]初来乍到

    发表于 2014-10-9 23:51:03 | 显示全部楼层 |阅读模式
    对于很多系统而言,要实现屏蔽DOS攻击有很多方法,比较高效的是在网关或者防火墙层实现,但是对于单主机系统又只有web服务的话兴师动众的配置个防火墙没有太大必要,而linux下的iptables的配置比较麻烦,要针对一个IP地址进行动态的防护还需要给内核打个补丁,昨天晚上突然想到了新的 Servlet规范中的Filter也可以做一个这样的防止DOS攻击的东西,最起码可以将来自同一个IP的过多请求转发到执行效率更高的apache并返回一个非常简单的页面来减轻服务器的压力,以下就是原型:
    package filters;

    import java.io.IOException;
    import java.util.HashMap;
    import java.util.Map;

    import javax.servlet.Filter;
    import javax.servlet.FilterChain;
    import javax.servlet.FilterConfig;
    import javax.servlet.ServletException;
    import javax.servlet.ServletRequest;
    import javax.servlet.ServletResponse;
    import javax.servlet.http.HttpServletResponse;

       
      
      
       public class RequestFilter implements Filter {
       static long MAX_TIME = 10 * 1000;

       static int MAX_TIMES_PER_SECOND = 5;

       private Map requestMap;

       public void destroy() {
         requestMap = null;
       }

       public void doFilter(ServletRequest request, ServletResponse response,
           FilterChain chain) throws IOException, ServletException {
         String client = request.getRemoteAddr();
         RequestInfo requestInfo = (RequestInfo) requestMap.get(client);
         if (requestInfo != null) {
           //如果请求信息太老就重置
      
       if (requestInfo.isTooOld()) {
             requestInfo.reset();
             chain.doFilter(request, response);
           } else {
             requestInfo.newRequest();
             //如果请求太多就重定向到错误页面
             if (requestInfo.isTooMuch()) {
               System.out.println("Too much request from "+client);
               ((HttpServletResponse) response).sendRedirect("/toomuch.htm");
             } else {
               chain.doFilter(request, response);
             }
           }
         } else {
           requestInfo = new RequestInfo();
           requestMap.put(client, requestInfo);
           chain.doFilter(request, response);
         }
       }

       public void init(FilterConfig filterConfig) throws ServletException {
         requestMap = new HashMap();
       }

       class RequestInfo {
         long firstTime;

         long lastTime;

         int count;

         public RequestInfo() {
           firstTime = System.currentTimeMillis();
           lastTime = System.currentTimeMillis();
           count = 1;
         }

         public void reset() {
           firstTime = System.currentTimeMillis();
           lastTime = System.currentTimeMillis();
           count = 1;
         }

         public void newRequest() {
           lastTime = System.currentTimeMillis();
           count++;
         }

         public boolean isTooMuch() {
           int seconds=(int)((lastTime - firstTime) / 1000);
           if (seconds==0) {
             seconds=1;
           }
           int times = (int) (count /seconds );
           if (times > MAX_TIMES_PER_SECOND) {
             return true;
           } else {
             return false;
           }
         }

         public boolean isTooOld() {
           if (System.currentTimeMillis() - firstTime > MAX_TIME) {
             return true;
           } else {
             return false;
           }
         }
       }
    }


         使用这个方法的另外一个好处是对于防止的策略可以非常的灵活,允许多大强度的访问可以自己修改代码完全控制。
    这个类还有一个问题是必须是在apache+tomcat这样的环境下,jsp转发给tomcat,而图片,js以及css什么的都是apache处理的,这样打开一个网页的时候对tomcat的请求数才不会太多而导致误判。
    回复

    使用道具 举报

    您需要登录后才可以回帖 登录 | 立即注册

    本版积分规则

    QQ|手机版|Java学习者论坛 ( 声明:本站资料整理自互联网,用于Java学习者交流学习使用,对资料版权不负任何法律责任,若有侵权请及时联系客服屏蔽删除 )

    GMT+8, 2024-6-16 08:33 , Processed in 0.383933 second(s), 48 queries .

    Powered by Discuz! X3.4

    © 2001-2017 Comsenz Inc.

    快速回复 返回顶部 返回列表