Cookie(会话)
1.2 Cookie
1.2.1 Cookie保存数据的原理
关于Cookie:
(1)Cookie是基于Set-Cookie响应头和Cookie请求头将会话中产生的数据保存在客户端浏览器中的。
(2)通过Set-Cookie响应头将数据发送给浏览器,让浏览器以cookie的形式保存在浏览器内部。
(3)保存在浏览器内部的cookie,在浏览器以后的每一次访问服务器时都会以Cookie请求头,将之前保存的cookie再带给服务器。
1.2.2 Cookie的API
1)、创建Cookie对象
2)、将Cookie添加到response响应中
3)、获取请求中的所有cookie对象组成的数组
4)、删除Cookie
没有提供直接删除cookie的方法,可以间接删除!
由于浏览器是根据cookie的名字来区分一个cookie的,如果前后服务器发送给浏览器两个同名的cookie,后发送的cookie就会覆盖之前发送的cookie。又由于后发送的cookie生存时间设置为0,浏览器收到后也会立即删除!
5)、Cookie的常用方法
6)、setMaxAge方法
1.2.3 cookie保存中文数据的问题
浏览器和服务器在通信时是遵循HTTP协议的。
而HTTP协议中规定了请求和响应信息中不能有中文数据。因此在发送中数据时,都需要进行URL编码。
张飞 --URL编码–> %E5%BC%A0%E9%A3%9E
服务器接收到URL编码后的数据,会进行URL解码操作。
%E5%BC%A0%E9%A3%9E --URL解码–> 张飞
因此在往cookie中保存中文数据之前,需要先编码,例如:
在将URL编码后的数据从Cookie取出来后,需要进行URL解码,例如:
1.2.4 cookie的细节
服务器是否能够无限制的给浏览器发送cookie?
一个服务器能够给浏览器发送的cookie个数是有限制的,浏览器的不同,限制的个数也有所不同(50、30、20等),所以给浏览器的发送的cookie个数最好不要超过20个!
cookie的大小有没有限制?
服务器给浏览器发送的每一个cookie的大小限制为1kb或者是4kb。因此我们发送的cookie大小最好不要超过1kb。