第一种方式:使用内置tomcat容器配置
在application.properties配置:java
#session过时时间(单位秒) 默认1800s(30min) #设置小于60秒,则会默认取1分钟 #实际过时时间为秒数对分钟取整,好比设置2000,则 2000s/60=33min,33min*60=1980s,实际过时时间为1980s server.session.timeout=3600
说明:该种方式只有使用内部tomcat时有效(EmbeddedServletContainerCustomizer原理是同样的,也是只有使用内部tomcat时有效),将工程打war包使用外部tomcat等容器是无效的。tomcat
第二种方式:使用shiro配置
在shiro config中配置:session
@Bean(name = "sessionManager") public DefaultWebSessionManager sessionManager() { DefaultWebSessionManager sessionManager = new DefaultWebSessionManager(); // 设置session过时时间3600s sessionManager.setGlobalSessionTimeout(3600000L); return sessionManager; } @Bean public SecurityManager securityManager() { DefaultWebSecurityManager securityManager = new DefaultWebSecurityManager(); securityManager.setRealm(customRealm()); securityManager.setSessionManager(sessionManager()); return securityManager; } @Bean public CustomRealm customRealm() { CustomRealm customRealm = new CustomRealm(); return customRealm; }
其余方式
HttpServletRequest request.getSession().setMaxInactiveInterval(interval)
if(SecurityUtils.getSubject()!=null) { SecurityUtils.getSubject().getSession().setTimeout(1800000L); }
测试
System.out.println("Session过时时间"+request.getSession().getMaxInactiveInterval()); System.out.println("shiro-Session过时时间"+SecurityUtils.getSubject().getSession().getTimeout());
说明:上述2个值是同样的。配置shiro-Session的优先级高于使用servlet的session。app
———————————————— 版权声明:本文为CSDN博主「阳光女孩666」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处连接及本声明。 原文连接:https://blog.csdn.net/zltAlma/article/details/88800290