一.session
1.session的过时时间是从何时开始计算的?是从一登陆就开始计算仍是说从中止活动开始计算?
从session不活动的时候开始计算,若是session一直活动,session就总不会过时。
从该Session未被访问,开始计时; 一旦Session被访问,计时清0;sessionid有效期内不会变。
session 是借助 cookie 实现的。另外,清空客户端cookie,session就会丢失。java
2.设置session的失效时间,若是session还在有效期就不会从新生成。
web.xml中web
<session-config> <session-timeout>30</session-timeout> </session-config>
//单位为分钟cookie
3.http请求时,不管http头指定了多少个 sessionid, 最终都只能操做一个会话,
若是指定的 sessionid 不合法,会自动建立新的 sessionsession
二.request.getSession()的用法进行总结:
在javaweb项目中,用到request.getSession()通常是存储信息到session中或者从session中获取信息。
通常有三种参数设置方式:
1.request.getSession()
这是经常使用的方式,从当前request中获取session,若是获取不到session,则会自动建立一个session,默认为true,并返回新建立的session;若是获取到,则返回获取到的session;
2.request.getSession(true)
这种方法和第一种同样,只是增家了一个true参数,告诉它在获取不到的时候自动建立session;
3.request.getSession(false)
这种方法与上两种的区别,就是在获取不到session的时候,不会自动建立session,而是会返回null。
在使用过程当中,通常想要存储到session中时,使用request.getSession(),
想要获取session中的信息时,使用request.getsession(false),并在获取后对session变量进行是否为null的判断,再进行下一步操做spa
4.怎么判断session是否过时。
session不存在就是session过时了,可进行以下判断,方法以下:code
if(request.getSession(false)==null){
System.out.println("Session has been invalidated!");
}
else{
System.out.println("Session is active!");
}