首页 > 代码库 > Session

Session

1. Web服务器跟踪客户状态通常有四种状态:

    1). 建立含有跟踪数据的隐藏字段(hide)

    2). 重写包含额外参数的URL(重定向的时候,将参数信息附加到URL后面)

    3). 使用持续的Cookie

    4). 使用Servlet API中的Session(会话)机制

2. 当一个Session开始时,Servlet容器将创建一个HttpSession对象,在HttpSession对象中可以存放客户状态的信息(例如购物车)。

3. Servlet容器为HttpSession分配一个惟一标志符,称为Session ID。Servlet容器把Session ID作为Cookie保存在客户浏览器进程中,当关闭浏览器后,

     cookie消失。这种cookie称为会话cookie。会话cookie存储在浏览器进程内存中,当关闭浏览器时, 浏览器进程释放所占的内存,导致cookie消失,

    sessionId也消失。所以再次访问服务器时,服务器会认为这是一个新的会话。

 

4. 每次客户发出HTTP请求时,Servlet容器可以从HttpServletRequest对象中读取Session ID,然后根据Session ID找到相应的HttpSession对象,从而获取

     客户的状态信息。

5. HttpSession接口常用方法:

    1). getId()返回Session的ID

    2). invalidate() 使当前的Session失效,Servlet容器会释放HttpSession对象占用的资源

    3). setAttribuate(String name, Object value) 将一对name/value属性保存在HttpSession对象中

    4). getAttribute(String name) 根据name参数返回保存在HttpSession对象中的属性值

    5). isNew()判断是否是新创建的Session。如果是新创建的Session,返回true,否则返回false

    6). setMaxInactiveInterval() 设定一个Session可以处于不活动状态的最大时间间隔,以秒为单位。如果超过这个时间,Session自动失效。如果设置为负数,

         表示不限制Session处于不活动状态的时间

6. 当客户第一次访问Web应用中支持Session的某个网页时,就会开始一个新的Session。接下来当客户浏览这个Web应用的不同网页时,始终处于同一个Session中。

     默认情况下,JSP网页都是支持Session的,也可以通过以下语句显式声明支持Session:<%@ page session= "true">

7. 在以下情况中,Session将结束生命周期,Servlet容器会将Session所占用的资源释放掉:

    1). Session过期

    2). 服务器端调用了HttpSession的invalidate()方法

 

Session