关于Cookie项目实践后知道的

在知乎上回答过 Cookie 从哪里来,网站用它来干嘛? 这样一个问题,它只介绍了Cookie是什么。但作为一个职场多年,发现很多工作数年的同事,对Cookie对理解仍旧还不够。这才有了这篇文章,尝试从实用对角度来介绍Cookie。

1. Cookie和其他本地存储

最常见用到对本地存储除了Cookie之外,还有localStorage和sessionStorge,它们是客户端主动写,和Cookie主要由服务器写(set-cookie)有所不同。

localStorage和sessionStorge之间则存在着有效期、作用域的差别,可以参考:JavaScript权威指南 第20章 存储 的第1.2节。

2. 第一方和第三方Cookie

image.png

以打开 https://www.jianshu.com 为例,可以看到Cookies栏包含了来自 https://www.jianshu.comhttps://googleads./g.doubleclick.net 的Cookie。

其中打开网址种的Cookie叫第一方Cookie,网址引用的资源(比如图片 js)所属服务器所种的Cookie叫第三方Cookie。第三方Cookie的一个应用,就是广告商用于分析用户数据,2020年Google已经在申明中湖i逐步取消第三方Cookie的权限。

3. Cookie怎么种上的

image.png

第二节中看到了jianshu种下了9个Cookie,查看 https://www.jianshu.com的Response,可以看到通过Set-Cookie,写了4个Cookie。

另外可以通过在请求中加载的JS代码中,看到setCookie的代码,可见jianshu也利用JS在本地设置了一些Cookie。

4. Cookie被使用的规则

一句话概括:Cookie被种哪里(文档+路径)下,发出这个规则的请求就会携带Cookie。

比如在 www.jianshu.com 下种了__yadk_uid,那么访问https://www.jianshu.com/p/207585cb1bc5
的时候,就会携带这个Cookie。

image.png

而假如jianshu的服务器后端接口域名为api.jianshu.com,那么上述Cookie就不会被携带,而.jianshu.com种的sensorsdata2015jssdkcrosssajssdk_2015_cross_new_user就会被带上。

5. 关于Cookie的作用域和有效期

我们在一个浏览器tab上登陆了jianshu以后,在新的浏览器tab打开,肯定是不用再重新登陆的,也就是说作用域应该是文档+路径(为什么不说域名,后面会介绍)相关联的,只要还是这个文档+路径,就仍旧可以访问到这个Cookie。

通过第2节中的图片,我们看到又一栏叫Expires/Max-Age,也就是说Cookie的有效期是的服务器可以设定的,可以是具体实践,也可以是想session这样的。

6. 只有文档(页面)可以中Cookie吗

因为系统登陆是通过接口登陆的,在登陆成功后,很多后端实现会在Response中也通过Set-Cookie来往浏览器上写Cooike。

下图是一个例子,一个后端调用的Response中携带了Token信息,并且指定了对 eleme.test 域名起作用。

image.png

这里比较容易误解的一点是,如果你访问了a.com网站,如果它的后端地址是b.com并且Cookie也是种在这个地址上,那么直接通过浏览器对Application-Cookies中能看到的仅是和a.com相关的第一方和第三方的Cookie。

想查看b.com的Cookie,可以直接拷贝 b.com的地址在浏览器上访问,然后通过查看Network,就可以看到在b.com上的Cookie。

7. 关于Cookie的更多

JavaScript权威指南 第20章 存储 比较详细的介绍了Cookie,仅本篇文章还不足以介绍它的文档+路径的概念,有效期的设置,以及Secure、HttpOnly等的使用。

当然随着使用也会发现一些在你理解之外的东西,这里先归档如下,期望你来解答。

问题1: 设置Domain和服务器地址不一致

在实际观察中(如下图标记为3的位置),发现一个Domain中的地址可以和源文档没有任何关系,即网站是 a.b.com,却可以设置Cookie在xyz.com上,而不仅限于 a.b.com.b.com,这是为什么呢?岂不是可以随意覆写其他Domain的Cookie值?

image.png
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 161,601评论 4 369
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 68,367评论 1 305
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 111,249评论 0 254
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 44,539评论 0 217
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 52,967评论 3 295
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 40,929评论 1 224
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 32,098评论 2 317
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 30,825评论 0 207
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 34,609评论 1 249
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 30,796评论 2 253
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 32,282评论 1 265
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 28,603评论 3 261
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 33,277评论 3 242
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 26,159评论 0 8
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 26,959评论 0 201
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 36,079评论 2 285
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 35,874评论 2 277