本文共 2226 字,大约阅读时间需要 7 分钟。
会话数据保存在浏览器客户端
会话数据保存在服务端
cookie类(来自servlet):用于存储会话数据
1.构造cookie对象:Cookie(java.lang.String name ,java.lang.String value)
2.设置Cookievoid setPath(java.lang.String url)设置Cookie的有效访问路径cookie.setPath(/绝对路径);
void setMaxAge(int expiry)设置Cooike的有效时间正整数:表示cookie数据保存浏览器的缓存目录(硬盘中),数值表示保存的时间
负整数:表示cookie数据保存浏览器的内存中,浏览器关闭cookie就丢失 零:表示删除同名的cookie数据void setValue(java.lang.String newValue)设置Cookie的值3.发送Cookie到浏览器端保存
void response.addCookie(Cookie cookie);
发送Cookie 4.服务器接受CookieCookie request.getCookies();
接受Cookie
cookie可以保存数据,但是cookie有条件限制,比如发送的内容只能是非中文的数据
HttpSession类:用于保存会话数据
HttpSession()
HttpSesion(boolean create)
void setmaxInactiveInterval(int interval):设置session有效时间
void invalidate():销毁session
java.lang.String getId():得到session的编号
void setAttribute(java.lang.String , java.lang.Object value):保存数据
java.lang.Object getAttribute(java.lang.String name):获取数据
void removeAttribute(java.lang.String name):清除数据
问题:服务器能够识别不同的浏览者
前提:从那个session域对象保存数据,就必须从哪个域对象取出
HttpSeeesion session = request.getSession();
java.lang.String getId():得到session的编号
getSesstion(true)/getSession(): 创建或得到session对象。没有匹配的session编号,自动创建新的session对象
getSession(false):得到session对象。没有匹配的session编号,返回null
session对象的销毁时间:
修改回收的时间
session.setMaxInactiveInterval(20);
< !--修改session的有效时间:分钟-->
1
void invalidate() 手动销毁session对象
/***手动发送一个硬盘保存的cookie给浏览器*/Cookie c = new Cookie("JCOOKIEID",session.getId());c.setMaxAge(60*60); //保存一小时response.addCookie(c);
- 会话管理:浏览器和服务器会话过程中的产生的会话数据管理
- Cookie技术:new Cookie ("name","value") response.addCookie(cookie); request.getCookies()
- Session 技术 request.getSession(); setAttribute("name","会话数据"); getAttribute("会话数据");
转载地址:http://lbjka.baihongyu.com/