Session用于跟踪客户的状态。Session指的是在一段时间内,单个客户与Web服务器的一连串相关的交互过程,在一个Session中,客户可能会多次请求访问同一个网页,也可能请求访问各种不同的服务器资源。
例子1:在电子邮件应用中,从一个客户登录到电子邮件系统开始,经过收信,写信,发信等一系列操作,直至最后退出邮件系统,整个过程都是一个Session。
例子2:在购物网站应用中,从一个客户开始购物,到最后结账,整个过程为一个Session。
Session的运行机制
1、当一个session开始时,Servlet容器将创建一个HttpServlet对象,在HttpServlet对象中可以存放客户的状态信息。(例如购物车);
2、Servlet容器为HttpSession分配一个唯一的标识符,称为Session ID。Servlet容器将Session ID作为Cookie保存在客户的浏览器中。
3、每次客户发出Http请求时,Servlet容器可以从HttpServletRequest对象中读取Session ID ,然后根据Session ID找到相应的HttpServlet对象,从而获取客户额状态信息。
HttpSession接口的一些常用方法:
session是httpSession的实例
String getId(): 返回的字符串由Servlet容器分配的。
invalidate():使当前的Session失效,Servlet容器会释放httpServlet对象占用的资源。
getAttribute( String name, Object value)和setAttribute(String name);
boolean isNew(): 特别地,如果客户端禁用掉cookie,则服务器会new 一个新的sessionid。
void setMaxInactiveInterval(int interval):以秒为单位,设置session处于不活动状态的最大时限,负数为一直存活。
好的博客关于session的:http://facer.me/1372.html