首页 > 编程语言 > 详细

使用java防止非法请求

时间:2020-02-04 18:57:47      阅读:169      评论:0      收藏:0      [点我收藏+]

1.过滤器

public class ImgFilter implements Filter {


    @Override
    public void init(FilterConfig filterConfig) throws ServletException {
        System.out.println("过滤器开始!!!");
    }

    @Override
    public void doFilter(ServletRequest request, ServletResponse response, FilterChain chain) throws IOException, ServletException {
        //获取当前请求的连接地址和上一个发送请求的地址
        HttpServletRequest httprequest=(HttpServletRequest) request;
        HttpServletResponse httpresponse=(HttpServletResponse) response;
        //获取上一个发送请求的连接
        String referer = httprequest.getHeader("Referer");
        String serverName = httprequest.getServerName();
        System.out.println(referer+"\t"+serverName);
        //||!referer.startsWith("http://www.aproject.com")
        if (referer==null ||!referer.contains(serverName)){
            request.getRequestDispatcher("/img/ffqq.png").forward(request,response);
            return;
        }
        //放行
        chain.doFilter(request,response);
    }

    @Override
    public void destroy() {
        System.out.println("过滤器销毁!!!");
    }
}

 

 

2.web.xml

<filter>
    <filter-name>ImgFilter</filter-name>
    <filter-class>com.szh.ImgFilter</filter-class>
  </filter>
  <filter-mapping>
    <filter-name>ImgFilter</filter-name>
    <url-pattern>/img/*</url-pattern>
  </filter-mapping>

 

 

正常访问

技术分享图片

 

 

 

 

非法访问  从另一个项目中访问图片

 技术分享图片

 

使用java防止非法请求

原文:https://www.cnblogs.com/1314Justin/p/12260220.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!