过滤器的使用步骤

使用场景:如,

需要用到登陆状态的认证,用户在没登陆的情况下就不能访问管理页面,访问后会跳回登陆页面。

在每个页面都加上判断显然不大现实,使用过滤器Filter来简化步骤。

1.配置web.xml文件设置过滤器

    <filter>       
             <filter-name>loginFilter</filter-name>       
             <filter-class>com.filter.LoginFilter</filter-class>       
        </filter>       
          <filter-mapping>    
             <filter-name>loginFilter</filter-name>    
             <url-pattern>/*</url-pattern>    
      </filter-mapping>  

2.在登录action中:登录成功后,向session中写入一个值,最为是否登录成功的标记


1 HttpServletRequest request = ServletActionContext.getRequest();
2 request.getSession().setAttribute("username", username);


3.编辑对应的过滤器类LoginFilter:过滤器检查session中username的值是否为空,为空则跳转至登陆页面


    package com.filter;  
       
     import java.io.IOException;  
     import javax.servlet.Filter;  
     import javax.servlet.FilterChain;  
     import javax.servlet.FilterConfig;  
     import javax.servlet.ServletException;  
     import javax.servlet.ServletRequest;  
     import javax.servlet.ServletResponse;  
     import javax.servlet.http.HttpServlet;  
     import javax.servlet.http.HttpServletRequest;  
     import javax.servlet.http.HttpServletResponse;  
     import javax.servlet.http.HttpSession;  
       
     public class LoginFilter extends HttpServlet implements Filter {  
         public void destroy() {  
         }  
       
         public void doFilter(ServletRequest sRequest, ServletResponse sResponse,        
                 FilterChain filterChain) throws IOException, ServletException{  
               
             HttpServletRequest request = (HttpServletRequest) sRequest;        
             HttpServletResponse response = (HttpServletResponse) sResponse;        
             HttpSession session = request.getSession();        
             String url=request.getServletPath();    
             String contextPath=request.getContextPath();    
             if(url.equals("")) url+="/";    
             if((url.startsWith("/")&&!url.startsWith("/login"))){//若访问后台资源 过滤到login    
                  String user=(String)session.getAttribute("username");    
                  if(user==null){//转入管理员登陆页面    
                       response.sendRedirect(contextPath+"/login.jsp");   
                       return;    
                  }    
             }    
               filterChain.doFilter(sRequest, sResponse);      
         }    
       
         public void init(FilterConfig arg0) throws ServletException {  
       
         }  
     }  


这样就可以了,除了login页面外全部都会被过滤器检测。

注:

浏览器关闭后session将被销毁,用户需重新登陆。

退出操作则将session中的username值设置为null即可。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值