第五章 会话以及会话管理技术

1.会话概述:

什么是会话:从打开浏览器,到访问网页,到最终关闭浏览器,整个过程就是一次会话。

会话的特点:包含多个请求,一次完整的会话对应一个用户。

会话管理技术:

第一种:cookie技术:客户端技术

第二种:session技术:服务端技术.

购物车案例:买完商品后加入购物车,买的商品存到什么对象比较合适?

1.使用request域对象保存商品信息:

结论:使用request不可以保存商品信息,因为每次发送请求都会产生一个

新的请求对象。

会话及管理技术_servlet

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

会话及管理技术_cookie_02


结论:使用ServletContext对象保存商品信息可以,但是不合理。
所以在开发中,保存会话过程中产生的数据采用会话管理技术,也就是使用cookie
和session技术来保存会话过程中产生的数据。

2.Cookie对象

1.1什么是cookie

Cookie是一种会话管理技术,它是用来保存会话过程中产生的数据,然后在浏览器

和服务器交互时,会使用cookie里面保存的数据。

会话及管理技术_会话管理_03


注意:首次访问服务器时,浏览器不会携带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.显示用户的上次访问时间

会话及管理技术_会话管理_04


实现步骤:

[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();