我是靠谱客的博主 无奈花瓣,最近开发中收集的这篇文章主要介绍Filter拦截器(过滤器),觉得挺不错的,现在分享给大家,希望可以做个参考。

概述

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

 和servlet同样是三大组件之一

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

 


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

 

 

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

import javax.servlet.*;

 

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

 接下来是放行拦截器

 访问页面

 

 

 

 


@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() {
    }

}

 

最后

以上就是无奈花瓣为你收集整理的Filter拦截器(过滤器)的全部内容,希望文章能够帮你解决Filter拦截器(过滤器)所遇到的程序开发问题。

如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。

本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
点赞(58)

评论列表共有 0 条评论

立即
投稿
返回
顶部