Java--过滤器LoginFilter实现会话超时跳转登录页面

举报
吾日三省贾斯汀 发表于 2021/09/10 00:37:50 2021/09/10
【摘要】 一、说明 1、网站系统登录,从安全的角度来考虑,登录会话超时,再次页面会退到登录界面。 2、本文配置如何通过过滤器(Filter)实现会话超时(如30分钟)跳转到登录页面,分LoginFilter.java类和web.xml配置两部分。 二、实现代码 过滤器类LoginFilter.java   package co...

一、说明

1、网站系统登录,从安全的角度来考虑,登录会话超时,再次页面会退到登录界面。
2、本文配置如何通过过滤器(Filter)实现会话超时(如30分钟)跳转到登录页面,分LoginFilter.java类和web.xml配置两部分。

二、实现代码

过滤器类LoginFilter.java

 


  
  1. package com.sale.filter;
  2. import java.io.IOException;
  3. import javax.servlet.Filter;
  4. import javax.servlet.FilterChain;
  5. import javax.servlet.FilterConfig;
  6. import javax.servlet.ServletException;
  7. import javax.servlet.ServletRequest;
  8. import javax.servlet.ServletResponse;
  9. import javax.servlet.http.HttpServletRequest;
  10. import javax.servlet.http.HttpServletResponse;
  11. import javax.servlet.http.HttpSession;
  12. /**
  13. * @author 作者:Justin
  14. * @version 创建时间:2018年1月25日 上午10:36:23
  15. * 类说明
  16. */
  17. public class LoginFilter implements Filter {
  18. @Override
  19. public void destroy() {
  20. // TODO Auto-generated method stub
  21. }
  22. @Override
  23. public void doFilter(ServletRequest req, ServletResponse res,
  24. FilterChain chain) throws IOException, ServletException {
  25. HttpServletRequest httpReq=(HttpServletRequest)req;
  26. HttpServletResponse httpRes=(HttpServletResponse)res;
  27. HttpSession httpSession=httpReq.getSession();
  28. String path = httpReq.getRequestURI(); //当前请求相对url
  29. String loginUrl = httpReq.getContextPath()+ "/loginout.action"; //1.登录界面url
  30. String initUrl = httpReq.getContextPath()+ "/tevo_loginInit.action"; //2.初始化界面url
  31. String userName = (String)httpSession.getAttribute("currentUsername"); //在session中获取当前用户名
  32. // 1、登陆页面、初始化页面不过滤
  33. if(loginUrl.equals(path) || initUrl.equals(path)) {
  34. chain.doFilter(req, res);
  35. return;
  36. }
  37. //
  38. if(userName==null){
  39. httpRes.sendRedirect(loginUrl);
  40. return;
  41. }else{
  42. chain.doFilter(req, res);
  43. return;
  44. }
  45. }
  46. @Override
  47. public void init(FilterConfig arg0) throws ServletException {
  48. // TODO Auto-generated method stub
  49. }
  50. }

web.xml配置


  
  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <web-app xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns="http://java.sun.com/xml/ns/javaee" xmlns:web="http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd" xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-app_3_0.xsd" id="WebApp_ID" version="3.0">
  3. <!-- configure loginFilter -->
  4. <filter>
  5. <filter-name>loginFilter</filter-name>
  6. <filter-class>com.sale.filter.LoginFilter</filter-class>
  7. </filter>
  8. <filter-mapping>
  9. <filter-name>loginFilter</filter-name>
  10. <url-pattern>*.action</url-pattern>
  11. </filter-mapping>
  12. <!-- configure session timeout 30 minute -->
  13. <session-config>
  14. <session-timeout>30</session-timeout>
  15. </session-config>
  16. </web-app>

 

文章来源: blog.csdn.net,作者:吾日三省贾斯汀,版权归原作者所有,如需转载,请联系作者。

原文链接:blog.csdn.net/JustinQin/article/details/79178725

【版权声明】本文为华为云社区用户转载文章,如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱: cloudbbs@huaweicloud.com
  • 点赞
  • 收藏
  • 关注作者

评论(0

0/1000
抱歉,系统识别当前为高风险访问,暂不支持该操作

全部回复

上滑加载中

设置昵称

在此一键设置昵称,即可参与社区互动!

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。