Session过期处理_1

本文介绍了一种基于Java Servlet的会话管理过滤器实现方案,该方案通过自定义过滤器来检查用户的会话状态,并根据不同的场景进行跳转或设置响应头。此外,还详细说明了如何在web.xml中配置此过滤器。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

1、普通请求处理,添加过滤器

public class MySessionFilter implements Filter,
  com.sun.org.apache.xalan.internal.xsltc.dom.Filter {
 private static final Logger log=LoggerFactory.getLogger(MySessionFilter.class);

@Override
 public void destroy() {
  // TODO Auto-generated method stub
  
 }

@Override
 public void doFilter(ServletRequest request, ServletResponse response,
   FilterChain chain) throws IOException, ServletException {
     log.info("=========start MySessionFilter.dofiter()=============");
   HttpServletRequest hrequest=(HttpServletRequest)request; 
   HttpServletResponse hResponse=(HttpServletResponse)response;
   HttpSession  session= hrequest.getSession(false);
   log.info(hrequest.getServletPath());
   if(hrequest.getServletPath().endsWith("/login.do") || hrequest.getServletPath().endsWith("/product.do")){
    chain.doFilter(request, response);
   }else{
    if(session!=null){
     chain.doFilter(request, response);
    }else{
    //session过期判断是不是ajax 请求,如果是ajax请求,就会在响应头里,sessionstatus有一个timeout
      if(hrequest.getHeader("x-requested-with")!=null &&
        hrequest.getHeader("x-requested-with").equals("XMLHttpRequest")){
       hResponse.setHeader("sessionstatus", "timeout");
      }else{
       hResponse.sendRedirect(hrequest.getContextPath() + "/login.do");
          return ;
      }
   
    }
   }
 }

 

2、在web.xml中配置 session过滤器,session过滤器放在其他过滤器前面

 

 Session过期处理_1

   

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值