Java web.xml session-config 属性配置

在Java Web开发中,Session为我们提供了很多方便,Session是由浏览器和服务器之间维护的。Session超时理解为:浏览器和服务器之间创建了一个Session,由于客户端长时间(休眠时间)没有与服务器交互,服务器将此Session销毁,客户端再一次与服务器交互时之前的Session就不存在了。

设置Session超时时间方式:

方式一:在代码工程web.xml中设置session-config如下,是针对单个应用而言:

 
 <session-config>
  <session-timeout>2</session-timeout>
 </session-config>
 即客户端连续两次与服务器交互间隔时间最长为2分钟,2分钟后session.getAttribute()获取的值为空

 API信息:

 
  session.getCreationTime()   获取session的创建时间
  session.getLastAccessedTime()  获取上次与服务器交互时间
  session.getMaxInactiveInterval() 获取session最大的不活动的间隔时间,以秒为单位120秒。
方式二: 在Tomcat的/conf/web.xml中session-config,默认值为:30分钟,针对整个容器而言

<session-config>
        <session-timeout>30</session-timeout>
</session-config>
方式三: 在Servlet中设置

 
  HttpSession session = request.getSession();
  session.setMaxInactiveInterval(60);//单位为秒
说明:

 1.优先级:Servlet中API设置 > 程序/web.xml设置 > Tomcat/conf/web.xml设置

 2.客户端与服务器一次有效会话(session没有超时),每次访问sessionId相同,若代码中设置了session.setMaxInactiveInterval()值,那么这个session的最大不活动间隔时间将被修改,并被应用为新值。

 3.Session的销毁(代表会话周期的结束):在某个请求周期内调用了Session.invalidate()方法,此请求周期结束后,session被销毁;或者是session超时后自动销毁;或者客户端关掉浏览器

扫描二维码关注公众号,回复: 6436514 查看本文章

总结:在程序开发过程中,我们可以在客户端每次与服务器交互时检查SessionID(Session中属性值,非HttpServlet环境开发中也可以用其它的Key值代替),用于会话管理。

猜你喜欢

转载自blog.csdn.net/qq_36838191/article/details/91382562