一、 为什么要 Web 状态管理
对于每个容器而言每个请求都相当于一个新的客户,因为当服务器生成 Response 返回到客户端,在客户端显示出来后相对应的 Socket 就会关闭,所以 HTTP 协议是个无状态的协议,他不能保存当前用户的信息。
二、 实现状态管理的方式
1. 在网页中表单中添加隐藏字段
缺点:需要每次在 Servlet 中动态生成这种隐藏字段。
2. 利用 Cookie
缺点:所有的信息都保存在客户端,不安全。浏览器关闭后代表着当前 cookie 就过期了。
3. 利用 Session
优点:在客户端 cookie 中只保存一些不重要的信息,比如 SessionID 等内容,重要信息保存在服务器端,这样安全。而且当客户端禁用了 cookie 后能够利用 URL 重写实现。当客户端关闭后服务器端的 Session 不会销毁。
三、 Cookie
Cookie coo = new Cookie(“xzw”,” 2005”);
response.addCookie(coo);
coo.getMaxAge(5);
四、 Session
通过 request.getSession() 创建 Session 对象,通过 invalidate() 使 Session 失效。
五、 URL 重写
Web 服务器会自动调用 Cookie 和 URL 重写,当客户端禁用 cookie 后会自动调用 URL 重写。
String str = response.encodeURL(“url”);
response.sendRirect(str);