session超时跳出frame -- Filter过滤器

本文介绍了如何在过滤器(Filter)中处理Session超时导致的跳转,确保用户在尝试访问非登录页面时,能够顺利跳转到登录页面。通过设置响应头禁止缓存和检查URL路径,实现有效的会话管理。

问题:

     session超时跳转后还在frame框架里面,得想办法跳出frame后转到登录页面去。

 

解决办法:

  Filter处理

 

 @Override
 public void doFilter(ServletRequest request, ServletResponse response,
   FilterChain chain) throws IOException, ServletException {
  //判断用户是否已经登录
  HttpServletRequest httpServletRequest = (HttpServletRequest)request;
  HttpServletResponse servletResponse  = (HttpServletResponse)response;
  //需要登录的东西不能被浏览器缓存
  servletResponse.setHeader("Pragma","No-cache");
  servletResponse.setHeader("Cache-Control","no-cache");   
 servletResponse.setDateHeader("Expires", -10);
  String appPath= httpServletRequest.getServletPath();
  if(!appPath.equalsIgnoreCase(loginUrl)&&!appPath.equalsIgnoreCase(loginActionUrl)&&!SessionUtil.exist(httpServletRequest, SessionUtil.USER_SESSION_NAME)){            
  servletResponse.sendRedirect(httpServletRequest.getContextPath()+loginUrl);
   return ;
  } 
 chain.doFilter(request, response);    
}


或者:


 

if(session == null || userDTO == null)//判断session是否失效。{ /*session失效后用户再次操作时页面将会跳回登录页面。*/ PrintWriter out = response.getWriter(); String url = request.getContextPath() + "/index.jsp"; out.println("<script language=\"javascript\">");//利用js跳出iframe。
 out.println("top.location=\"" + url + "\";"); out.println("</script>");}

 

注:在Filter中无论是forward还是redirct,之后最好return,不需要走 chain.doFilter(request, response); 在某些特殊的情况下可能就会存在问题。


转载于:https://my.oschina.net/u/1157906/blog/301841

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值