第五章 会话以及会话管理技术
1.会话概述:
 什么是会话:从打开浏览器,到访问网页,到最终关闭浏览器,整个过程就是一次会话。
 会话的特点:包含多个请求,一次完整的会话对应一个用户。
 会话管理技术:
 第一种:cookie技术:客户端技术
 第二种:session技术:服务端技术.
 购物车案例:买完商品后加入购物车,买的商品存到什么对象比较合适?
 1.使用request域对象保存商品信息:
 结论:使用request不可以保存商品信息,因为每次发送请求都会产生一个
 新的请求对象。

2.使用ServletContext域对象保存商品信息

 结论:使用ServletContext对象保存商品信息可以,但是不合理。
 所以在开发中,保存会话过程中产生的数据采用会话管理技术,也就是使用cookie
 和session技术来保存会话过程中产生的数据。
2.Cookie对象
 1.1什么是cookie
 Cookie是一种会话管理技术,它是用来保存会话过程中产生的数据,然后在浏览器
 和服务器交互时,会使用cookie里面保存的数据。

注意:首次访问服务器时,浏览器不会携带cookie到服务端。
 1.2 Cookie常用的API
[1].得到cookie对象:Cookie cookie=new Cookie(String key,String value);
 [2].回写(响应)cookie到浏览器端:response.addCookie(cookie);
 [3].得到cookie的名称:String key=cookie.getName();
 得到cookie的值:String value=cookie.getvalue();
 [4].给cookie设置生命时长:setMaxAge(int sr);
比如:cookie.setMaxAge(606024*7);//说明cookie能保存7天
 cookie分类:
(1)会话级别cookie:浏览器关闭,cookie对象就销毁了.
 (2)持久化cookie:通过setMaxAge()这个方法来设置
 [5].给cookie设置路径,设置域名.
 setPath(路径的url),setDomain(域名);
 比如:域名就是服务器名称,比如说:www.baidu.com
[6].得到cookie:Cookie[] cookies=request.getCookies();
 1.3.显示用户的上次访问时间

 实现步骤:
 [1]判断是否是首次访问:
 如果cookie里面有时间,说明就不是第一次访问。
 [2].如果是第一次访问,创建cookie,保存时间,把这个cookie回写到浏览器端。
 [3].如果不是第一次访问,把时间回写到浏览器,记住当前时间,把时间保存
 到cookie里面。
 例如:
//处理响应中文的乱码问题
response.setContentType("text/html;charset=utf-8");
//1.获取所有cookie
Cookie[] cookies=request.getCookies();
//2.遍历cookie数组
String lastTime=null;
for(int i=0;cookies!=null&&i<cookies.length;i++) {
//3.获取cookie的名称
String name=cookies[i].getName();
if("lastAccess".equals(name)) {
//获取cookie的时间
lastTime=cookies[i].getValue();
}
}
//3.判段是否是首次访问,如果cookie里有时间,就不是第一次访问,否则就是第一次访问
if(lastTime==null) {
//第一次访问:
response.getWriter().print("first");
}else {//说明不是第一次访问
//把上次访问的时间回写到浏览器
response.getWriter().print("lasttime:"+lastTime);
}
//第三次,第四次---
Date date = new Date();
SimpleDateFormat format = new SimpleDateFormat("yyyy-MM-dd-hh:mm:ss");
String currentTime = format.format(date);
Cookie cookie = new Cookie("lastAccess",currentTime);
cookie.setMaxAge(60*60*10);
response.addCookie(cookie);
如果你遇到报错:
java.lang.IllegalArgumentException: An invalid character [32] was present in the Cookie value
访问这里:javascript:void(0)3.Session对象
3.1 什么是session
 session是一种会话管理技术,session用来保存会话过程中的数据,保存的数据存
 储到服务器端。
session原理:基于cookie实现的,更确切地说时基于会话级别地cookie实现的。
3.2 HttpSession API
 session常用方法:
[1].得到session的id(JESSIONID对应的值):getId();
 [2].设置session的生命时长:setmaxInactiveInterval(int interval);
 [3].销毁session:invalidate();
 [4]得到session:HttpSession session=getSession();
 session域对象:作用范围一次完整的会话(包含多个请求).
 [1].存值:setAttribute(String key,Object obj);
 [2].取值:Object obj=getAttribute(String key);
 [3]移除值:removeAttribute(String key);
 总结:域对象: request域对象 session域对象 servletContext域对象,作用范围依次变大
 request域对象:作用范围一次请求,通常和转发操作配合使用
 session域对象:作用范围一次会话,通常和重定向操作配合使用
 servletContext域对象:作用范围整个项目,和重定向、转发操作都可以配合使用。
3.3 Session超时管理
 session对象是有生命时长,它的默认存活时间是30分钟
 具体配置找tomcat软件下/conf/web.xml文件
 30
 立即销毁session对象:invalidate();
                










