会话技术
会话:一次会话中包含多次请求和响应。
一次会话:浏览器第一次给服务器资源发送请求,会话建立,直到有一方断开为止
功能:在一次会话的范围内的多次请求间,共享数据
方式
客户端会话技术:Cookie
服务器端会话技术: Session
Cookie
概念
客户端会话技术,将数据保存到客户端
快速入门
使用步骤:
创建Cookie对象,绑定数据
new Cookie(String name ,String value)
发送Cookie对象
response.addCookie(Cookie cookie)
获取Cookie,拿到数据
Cookies[] request.getCookies()
实现原理
基于响应头set-cookie和请求头cookie实现
cookie的细节
能否一次发送多个cookie
可以。
可以创建多个Cookie对象,使用response调用多次addCookie(Cookie cookie);
cookie在浏览器中的保存时间
- 默认情况下,当浏览器关闭后,cookie数据被销毁
- 持久化存储
setMaxAge(int seconds)
- 正数:将cookie数据写入到硬盘的文件。持久化存储。
- 负数:默认值
- 零:删除cookie信息
cookie能否存入中文
- 在tomcat 8 之前 cookie不能直接存储中文数据
需要将中文数据转码 — 一般采用URL编码
- 在tomcat 8 之后 cookie支持存储中文数据
cookie的获取范围
1.假设在一个tomcat服务器中,部署了多个web项目,那在这些web项目中cookie能不能共享?
默认情况下cookie不能共享
setPath(String path):设置cookie的获取范围。默认情况下,设置当前的虚拟目录。
如果要共享,则可以将path设置为”/。”
2.不同的tomcat服务器间cookie共享问题?
setDomain(String path):如果设置一级域名相同,那么多个服务器之间cookie可以共享
例如:
setDomain(“.baidu.com”)
那么tieba.baidu.com和news.baidu.com中的Cookie可以共享
cookie的特点
- cookie存储数据在客户端浏览器
- 浏览器对于单个cookie的大小有限制(4kb) 以及 对同一个域名下的总cookie数量也有限制
作用:
- cookie一般用于存储少量的不太敏感的数据
- 在不登录的情况下,完成服务器对客户端的身份识别
Session
概念
服务器会话技术,在一次会话的多次请求间共享数据,将数据保存在服务器端的对象中。HttpSession
快速入门
HttpSession对象:
Object getAttribute(String name)
void setAttribute(String name , Object value)
void removeAttribute(String name)
nn