数据存储(一)Cookie
admin
2024-02-10 14:55:32
0

参考:《JavaScript 高级程序设计》(第3版)

1. 背景

cookie 最初由网景公司创造,解决将数据存储在客户端上的问题。

Persistent Client State: HTTP Cookies(持久客户端状态:HTTP Cookies)的标准中对 cookie 进行了阐述,链接 => Client Side State - HTTP Cookies

2. 解释 

用来在客户端存储会话信息,以及和服务端进行通信。

HTTP Cookie 标准要求服务器对任意HTTP请求发送 Set-Cookie 响应头,其中包含会话信息。

  • 响应头 Set-Cookie: name=value

浏览器接收到之后,把会话信息存储下来,并通过为每个请求添加 Cookie 请求头将信息发送回服务器。

  • 请求头 Cookie: name=value

3. cookie 结构

部分描述关键字
名称

唯一确定cookie的名称。cookie名称不区分大小写。需要被URL编码。

存储在cookie中的字符串值。需要被URL编码。

cookie对于哪个域是有效的。所有向该域发送的请求中都会包含这个cookie信息。

例如:domain=.wrox.com;

domain=
路径

访问指定域中哪个路径可以发送cookie。

例如:指定path=http://www.wrox.com/books/;  则只有http://www.wrox.com/books这个路径下的请求会携带cookie,http://www.wrox.com不会携带。

path=
失效时间

表示cookie何时被删除,何时不会向服务器发送。值是GMT格式的日期。

例如:expires=Mon, 01-Jan-22 01:01:01 GMT;

expires=
安全标志

指定后,cookies只有在使用SSL链接时才发送到服务器。

secure

以上每一段信息都作为 Set-Cookie 的一部分,使用分号加空格,分隔每一段,如下:

Set-Cookie: name=value; expires=Mon, 01-Jan-22 01:01:01 GMT; domain=.wrox.com; path=/; secure

以上信息头指定了一个叫name的cookie,它会在格林威治时间2022年1月1日 01:01:01 失效,同时对于wrox.com的任何子域都有效,但协议需要是https。

子cookie

为了绕开浏览器单域名下cookie数量限制,可以使用子cookie(subcookie)的概念来更加结构化的存储数据。

常见格式如下:name1=value1&name2=value2

4. cookie 限制

cookie 限制
限制描述意义解决
1. 同源且不能跨会话

cookie在性质上是绑定在特定域名下的。当设定了一个cookie之后,再给创建它的域名发送请求时,都会包含这个cookie。

确保cookie不被恶意使用。(存储在cookie中的信息只能让批准的接受者访问,无法被其他域访问)需要跨会话存储信息,使用LocalStorage
2. Cookie 总数有限

① 不同浏览器对总数的限制不同

• Safari和Chrome没有硬性规定;

• IE7之前,每个域名最多20个;

• IE7及以上版本和Firefox,每个域名最多50个;

• Oprea,每个域名最多30个;

② 当超过限制后,继续设置cookie,浏览器会清除之前的cookie:

• IE和Opera会删除最近最少使用过的cookie

• FireFox随机清除

确保不占用过多的内存或磁盘空间可采用子cookie的形式存储
3. Cookie 尺寸有限

① 尺寸限制为 4096B(加减1)。

尺寸限制影响到一个域下所有的cookie,并非每个域单独设置。

② 当创建超过最大尺寸的cookie,该cookie会被丢弃。

确保不占用过多的内存或磁盘空间将长度限制在4095B之内
4. 需要URL编码cookie的名称和值必须经过URL编码,使用时也需要URL解码。服务器在接收字符串时,不允许空格和特殊字符等。为避免邮箱等带有特殊字符的传不过去,需要编码。

编码:

encodeURIComponent()

解码:

decodeURIComponent()

5. cookie 存储的位置

内存是临时存储(内存决定电脑能同时运行多少程序);

硬盘是长久存储(硬盘决定电脑能存放多少东西);

如果cookie有过期时间,就会被存储于硬盘中,过期后删除;

如果cookie没设置过期时间,就会被存储于内存中,会话结束时失效;

6. JavaScript中控制cookie

document.cookie 可用来获取、设置cookie。

/*** cookie的写入、读取、删除工具*/
var CookieUtil = {get: function (name) {let cookieName = encodeURIComponent(name) + "=",cookieStart = document.cookie.indexOf(cookieName),cookieValue = null;if (cookieStart > -1) {let cookieEnd = document.cookie.indexOf(";", cookieStart);if (cookieEnd == -1) {cookieEnd = document.cookie.length;}cookieValue = decodeURIComponent(document.cookie.substring(cookieStart + cookieName.length, cookieEnd));}return cookieValue;},set: function (name, value, expires, path, domain, secure) {let cookieText = encodeURIComponent(name) + "=" + encodeURIComponent(value);if (expires instanceof Date) {cookieText += "; expires=" + expires.toGMTString();}if (path) {cookieText += "; path=" + path;}if (domain) {cookieText += "; domain=" + domain;}if (secure) {cookieText += "; secure";}document.cookie = cookieText;},unset: function (name, path, domain, secure) {this.set(name, "", new Date(0), path, domain, secure);},
};// 调用
// 设置cookie
CookieUtil.set("name", "不头秃的码农");
CookieUtil.set("book","JavaScript",new Date("2022.11.30"),"/","baidu.com",true
);
// 读取cookie
console.log(CookieUtil.get("name"));
console.log(CookieUtil.get("book"));
// 删除cookie
CookieUtil.unset("name")
CookieUtil.unset("book")

7. 总结

由于所有的 cookie 都会由浏览器作为请求头发送,如果在 cookie 中存储大量的信息会影响特定域名的请求性能。cookie 信息越大,完成对服务器请求的时间就越长。再考虑到 cookie 有数量和大小的限制,所以尽可能少在 cookie 中存储信息。

不要在cookie中存储重要和敏感的隐私数据,cookie数据并非存储在一个安全环境中,其中包含的任何数据都可以被他人访问。

相关内容

热门资讯

安卓版pc端系统,跨越平台界限... 你有没有想过,你的安卓手机里的应用,竟然可以在电脑上无缝运行?没错,这就是安卓版PC端系统的魅力所在...
安卓7车机系统,科技与安全的完... 你有没有发现,现在的汽车越来越智能了?没错,我说的就是那些内置了安卓7车机系统的家伙们。想象当你坐在...
王者荣耀安卓系统区别,深度揭秘... 你有没有发现,玩王者荣耀的时候,安卓系统的手机和苹果系统的手机,感觉就像是两个不同的世界呢?今天,就...
盒子电视安卓9系统,畅享智能新... 亲爱的读者们,你是否曾为拥有一台功能强大、系统流畅的电视而心动?今天,我要给你介绍一款特别受欢迎的盒...
智慧吴江app安卓系统,安卓系... 你知道吗?最近吴江地区掀起了一股智慧风潮,一款名为“智慧吴江app”的应用在安卓系统上大受欢迎。这款...
苹果系统听歌app安卓,跨平台... 你有没有发现,无论是走在街头还是坐在家里,音乐总是能瞬间点燃我们的心情?而在这个音乐无处不在的时代,...
安卓系统卡顿根源,性能瓶颈与优... 手机用久了是不是感觉越来越卡?是不是每次打开应用都要等半天,甚至有时候直接卡死?别急,今天就来跟你聊...
电脑系统怎么装安卓系统,电脑系... 你有没有想过,把安卓系统装在你的电脑上,是不是就像给电脑穿上了时尚的新衣呢?想象你可以在电脑上直接使...
安卓系统华为手环app,健康管... 你有没有发现,现在的生活越来越离不开智能设备了?手机、平板、手表……这些小玩意儿不仅让我们的生活变得...
switch lite刷安卓系... 你有没有想过,你的Switch Lite除了玩那些可爱的任天堂游戏,还能干些什么呢?没错,今天我要给...
想买华为但是安卓系统,尽享安卓... 最近是不是也被华为的新款手机给迷住了?看着那流畅的线条和强大的性能,是不是心动了呢?但是,一想到安卓...
怎么拷安卓系统文件,安卓系统文... 你有没有想过,手机里的那些安卓系统文件,其实就像是一扇通往手机世界的秘密通道呢?想要深入了解你的安卓...
安卓系统移植按键失灵,安卓系统... 最近你的安卓手机是不是也遇到了按键失灵的尴尬情况呢?这可真是让人头疼啊!别急,今天就来给你详细解析一...
安卓系统更新管理在哪,全面解析... 你有没有发现,你的安卓手机最近是不是总在提醒你更新系统呢?别急,别急,今天就来手把手教你,安卓系统更...
安卓系统哪里出的,从诞生地到全... 你有没有想过,我们每天离不开的安卓系统,它究竟是从哪里冒出来的呢?是不是觉得这个问题有点儿像是在问星...
最好的电脑安卓系统,最佳电脑安... 亲爱的电脑迷们,你是否在寻找一款既能满足你工作需求,又能让你畅享娱乐的电脑操作系统呢?今天,我要给你...
安卓系统保密性,守护隐私的坚实... 你知道吗?在这个信息爆炸的时代,保护个人隐私变得比以往任何时候都重要。尤其是对于安卓系统用户来说,了...
苹果系统下载安卓版本,安卓版本... 你有没有想过,为什么苹果系统的手机那么受欢迎,却还有人想要下载安卓版本呢?这背后可是有着不少故事呢!...
安卓系统如何下载carplay... 你是不是也和我一样,对安卓系统上的CarPlay功能充满了好奇?想象在安卓手机上就能享受到苹果Car...
退回安卓系统的理由,揭秘安卓系... 你有没有想过,为什么有些人会选择退回到安卓系统呢?这可不是一件简单的事情,背后可是有着不少原因哦!让...