首先介绍一下session的一些常用方法
引用地址:http://blog.youkuaiyun.com/jaylongli/archive/2008/11/21/3344570.aspx
API上解释: HttpSession getSession()
Returns the current session associated with this request, or if the request does not have a session, creates one.
HttpSession getSession(boolean create)
Returns the current HttpSession associated with this request or, if there is no current session and create is true, returns a new session.
getSession() :无参数时,意思为有就不创建,没有就创建(简单点好,说太多反而会晕)。
getSession(boolean create) :参数为true时,实际上等于无参数的,意思如上。
参数为false时:不管session是否存在,都不创建,即没有就为空,有就返回。
注:创建是指新建一个新的对象
2、invalidate()
主要是对session的注销,通常用于用户登录情况的判断(也很多应用于同一账号不能重复登录)
今天无意想起来这个问题,然后自己也测试了一下,当然也少不了到网上找找相关答案了,答案很多,但是。。。。。
不废话了,直接说下吧。
当使用这个方法时,session实际上彻底注销的,即指当你在通过request.getsession()时,如果没有参数或参数为true时,返回的session已经不在是原来的session了(自己已通过得到sessionId的方式查看,重新新建了),如果参数为false时,返回的为null。
昨天晚上写一个功能,用到session传值,怎么也活不到值,一直想不明白,思维在session会话失效上打转
今天早晨来了后,查看下层层访问的路径
发现了毛病,其中走过的一个jsp中,写了 request.getSession(true).invalidate();
注销了,呵呵呵,以后在碰到这方面的问题时,一定要查看下自己访问的过程中是否出错