【Cookie】—— 浏览器上的小小甜点

 

会话技术

概念: 一次会话中包含多次请求和响应。
  ( 一次会话:浏览器第一次给服务器资源发送请求,会话建立,直到一方断开为止)

功能: 一次会话的多次请求之间,共享数据

方式:

  1. 客户端会话技术:Cookie
  2. 服务器端会话技术:Session

 
 

Cookie

概念:客户端会话技术,将数据保存到客户端
 
快速入门:

Cookie cookie = new Cookie("name", "value")		// 1. 创建Cookie对象,绑定数据

response.addCookie(Cookie cookie) 				// 2. 发送Cookie对象
Cookie[] cookies = request.getCookies()			// 3. 获取Cookie对象,拿到数据

cookie.getName()								// 4. 获取name
cookie.getValue()								// 4. 获取value

 
实现原理

基于响应头set-cookie和请求头cookie实现。
在这里插入图片描述
 
Cookie细节
 
Q:一次可不可以发送多个Cookie?

A:可以
 
Q:同name的Cookie会被覆盖吗?

A:会的。但是有一个比较奇怪之处:响应头中会存在同name的Cookie,然而在下次的请求头中只会留下一个,即发生了覆盖
 
Q:Cookie在浏览器中保存多长时间?

A:默认情况下,因为是存在浏览器内存中,当浏览器关闭后,Cookie数据被销毁
  持久化存储 setMaxAge(int seconds)(正数:将Cookie数据写到硬盘的文件中;负数:默认情况;0:立即删除Cookie)
 
Q:cookie能不能存储中文?

A:tomcat8新版本的Cookie虽然已经支持中文,但仍有一些特殊字符(比如space空格)出现乱码——因此最好在生成Cookie时,用URL编码多转化一次URLEncoder);读取Cookie时,用URL解码多转化一次URLDecoder)—— 参数是字符串返回值也是字符串,用起来很方便(URL编码形如"%E3%A3%Y6…")
 
Q:假设在一个tomcat服务器中,部署了多个web项目,那么在这些web项目中Cookie能不能共享?

A:默认不能共享setPath(String path)可以设置cookie的共享范围——默认情况下,其值为当前的虚拟目录,这正是一个tomcat下的多个web项目无法共享Cookie的原因。如果要共享,setPath("/")
 
Q:不同的tomcat服务器间Cookie可以共享吗?

A:竟然也是可以的!可以用setDomain(String path)设置相同的域名。
  比如和"baike.baidu.com"(百度百科)和"tieba.baidu.com"(百度贴吧)拥有相同的一级域名".baidu.com"

 

Cookie的特点和作用

特点:1. cookie存储数据在客户端浏览器,安全性相对服务器当然更低
   2. 浏览器对于单个cookie的大小有限制(4kb) ,对同一个域名下的总cookie数量也有限制(20个)(小而少

特点决定用途:

  1. cookie一般用于存储少量不太敏感的数据
  2. 离线(没用到数据库)的情况下,浏览器还是可以记住之前的一些设置和数据。服务器怎么知道又是"我"来了呢?正是因为上次访问时,服务器发送了一些Cookie到该页面上——下一次请求时这些Cookie被拿过来判断和使用
     

 
 

 

 

 

 

 

 

 

 

 

End ♬

by a Lolicon ✪

©️2020 CSDN 皮肤主题: 像素格子 设计师:CSDN官方博客 返回首页