java中如何用过滤器来拦截用户不允许访问的网页(通过地址栏来进行拦截)

过滤器用来拦截用户不允许访问的网页(通过地址栏来进行拦截)

例如:等用户在地址栏输入访问地址后跳转时进行拦截,只允许访问集合中存在的这些网页,在web.xml中先进行如下配置


FilterSerlvet
com.zt.filter.FilterSerlvet

code
utf-8



FilterSerlvet
/*

过滤器的写法

public class FilterSerlvet implements Filter {

               private List paths =new ArrayList();//实例化一个装路径的集合

      public void doFilter(ServletRequest arg0, ServletResponse arg1,
                         FilterChain chain ) throws IOException, ServletException {
               HttpServletRequest request =(HttpServletRequest) arg0;
               HttpServletResponse response =(HttpServletResponse) arg1;
               String contextPath =request.getContextPath();
               String path =request.getRequestURL().toString();
               System.out.println(contextPath);//  20170512filter2
               System.out.println(path);//  http://localhost:8080/20170512filter2/user1/list.jsp
               int num =path.indexOf(contextPath)+contextPath.length();
               String relpath =path.substring(num+1);
               if (paths.contains(relpath)) {
                         chain.doFilter(request, response);
               }else {
                         response.sendRedirect("../index.jsp");
               }

      }
      public void init(FilterConfig arg0) throws ServletException {
               // TODO Auto-generated method stub

           //将允许访问的网页路径放入集合中,实际开发中应该是从数据库中取允许访问的路径
               paths.add("user1/list.jsp");
               paths.add("user2/list.jsp");
               paths.add("user3/list.jsp");
               paths.add("index.jsp");
      }
      public void destroy() {
               // TODO Auto-generated method stub

      }

}

1. 创建一个过滤器类 MyFilter,实现 javax.servlet.Filter 接口。 ``` public class MyFilter implements Filter { @Override public void init(FilterConfig filterConfig) throws ServletException { // 初始化方法 } @Override public void doFilter(ServletRequest request, ServletResponse response, FilterChain chain) throws IOException, ServletException { // 过滤方法 } @Override public void destroy() { // 销毁方法 } } ``` 2. 在 doFilter 方法,判断请求是否来自本站。如果是本站请求,直接放行;否则,跳转到非法访问提示页面。 ``` public void doFilter(ServletRequest request, ServletResponse response, FilterChain chain) throws IOException, ServletException { HttpServletRequest httpRequest = (HttpServletRequest) request; String referer = httpRequest.getHeader("referer"); if (referer != null && referer.contains(request.getServerName())) { // 来自本站的请求,直接放行 chain.doFilter(request, response); } else { // 非法访问,跳转到提示页面 HttpServletResponse httpResponse = (HttpServletResponse) response; httpResponse.sendRedirect("/illegalAccess.html"); } } ``` 3. 在 web.xml 文件配置过滤器。 ``` <filter> <filter-name>myFilter</filter-name> <filter-class>com.example.MyFilter</filter-class> </filter> <filter-mapping> <filter-name>myFilter</filter-name> <url-pattern>/images/*</url-pattern> </filter-mapping> ``` 4. 在项目根目录下创建 illegalAccess.html 文件,用于显示非法访问提示信息。 这样,当用户直接访问图片时,会被 MyFilter 拦截,并跳转到非法访问提示页面;而当用户从本站页面链接过来时,可以正常显示图片。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值