过滤器及用户登录权限过滤

目录

  • 注册过滤器
  • 过滤器

    过滤器就是用来帮助程序员较少代码量的,可以使用过滤器统一规定数据的编码和登录权限过滤:

    1. Servlet过滤器是在Java Servlet规范2.3中定义的,它可以拦截指定页面或指定的Servlet对其进行过滤,满足条件则放行。
    2. Servlet过滤器本身并不产生请求和响应对象,它只能提供过滤作用,但Servlet过滤器可以向下转型,可以获取数据来修改数据。
    HttpServletRequest request = (HttpServletRequest) servletRequest;
    HttpServletResponse response = (HttpServletResponse) servletResponse;
    
    1. 过滤器,就相当于一本护照,没有护照你不能出国。
    2. 在version 3.0及以上时,可以直接在过滤器类的上面直接写@WebFilter(“/过滤对象“),不需要去web.xml里面配置,同理,Servlet也可以使用@webServlet("/Servlet的地址")。

    过滤器的使用

    实现过滤未登录用户访问其他页面

    未登录用户过滤实现:
    @WebFilter("/LoginPrivilegesFilter ")
    public class LoginPrivilegesFilter implements Filter {
        @Override
        public void init(FilterConfig filterConfig) throws ServletException {
    
        }
    
        @Override
        public void doFilter(ServletRequest servletRequest, ServletResponse servletResponse, FilterChain filterChain) throws IOException, ServletException {
            HttpServletRequest request = (HttpServletRequest)servletRequest;
            HttpServletResponse response = (HttpServletResponse)servletResponse;
            User user = (User) request.getSession().getAttribute(Constants.USERCODE);
            //用户为空表示,session内不存在值
            if(user==null){
                response.sendRedirect(request.getContextPath()+"/error.jsp");
            }else{
                filterChain.doFilter(servletRequest,servletResponse);
            }
        }
    
        @Override
        public void destroy() {
    
        }
    }
    
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值