Filter拦截器(过滤器)

Filter拦截器(过滤器)_第1张图片

不让浏览器直接访问我们的web资源 需要加一层拦截器 来过滤 比如没有登录就直接访问我的购物车等一些不合理操作

Filter拦截器(过滤器)_第2张图片

 和servlet同样是三大组件之一

所以和servlet的创建方式差不多 同样是实现一个接口 不过是filter的接口

Filter拦截器(过滤器)_第3张图片 


 测试 在不加filter拦截器的情况下 访问web资源

Filter拦截器(过滤器)_第4张图片 

 

Filter拦截器(过滤器)_第5张图片

 下面加上拦截器 实现Filter接口 注意是哪个包下面的

import javax.servlet.*;

Filter拦截器(过滤器)_第6张图片

 Filter拦截器(过滤器)_第7张图片

 页面同样访问 就会拦截下来 

Filter拦截器(过滤器)_第8张图片

 接下来是放行拦截器

Filter拦截器(过滤器)_第9张图片

 访问页面

Filter拦截器(过滤器)_第10张图片

Filter拦截器(过滤器)_第11张图片 Filter拦截器(过滤器)_第12张图片

 Filter拦截器(过滤器)_第13张图片

 Filter拦截器(过滤器)_第14张图片

 


@WebFilter("/*")
public class FilterLogin implements Filter {
    @Override
    public void doFilter(ServletRequest request, ServletResponse response, FilterChain chain) throws ServletException, IOException {
        //强转 把ServletRequest request 转行从HttpServletRequest request
        HttpServletRequest req = (HttpServletRequest) request;

        //判断是否和登录注册相关的请求
        String[] urls = {"/login.jsp", "/register.jsp", "/ServletLogin","/ServletRegister","/ServletCheckCode","/imgs/","/css/"};

        String url = req.getRequestURL().toString();
        //把相关的请求全部放在urls中 然后给放行
//循环判断urls中的url是否和url相等
        for (String s : urls) {
            if (url.contains(s)){
                //找到了就放行
                chain.doFilter(request, response);
                //结束
               return;
            }
        }
        //得到session
        User user = (User) req.getSession().getAttribute("user");
        if (user == null) {
            //没有登录 跳转到登录页面 提示信息
            req.setAttribute("filter_msg", "请先登录");
            //跳转到登录页面
            req.getRequestDispatcher("/login.jsp").forward(request, response);
        }else {
            chain.doFilter(request, response);
        }


    }
    public void init(FilterConfig config) throws ServletException {
    }


    public void destroy() {
    }

}

 

你可能感兴趣的:(java-ee)