Cookie

✍ dations ◷ 2025-02-23 14:00:29 #HTTP

Cookie(复数形态Cookies),又称为“小甜饼”。类型为“小型文本文件”,指某些网站为了辨别用户身份而储存在用户本地终端(Client Side)上的数据(通常经过加密)。由网景公司的前雇员卢·蒙特利在1993年3月发明。最初定义于RFC 2109。目前使用最广泛的 Cookie标准却不是RFC中定义的任何一个,而是在网景公司制定的标准上进行扩展后的产物。

Cookie总是保存在客户端中,按在客户端中的存储位置,可分为内存Cookie和硬盘Cookie。

内存Cookie由浏览器维护,保存在内存中,浏览器关闭后就消失了,其存在时间是短暂的。硬盘Cookie保存在硬盘里,有一个过期时间,除非用户手工清理或到了过期时间,硬盘Cookie不会被删除,其存在时间是长期的。所以,按存在时间,可分为非持久Cookie和持久Cookie。

因为HTTP协议是无状态的,即服务器不知道用户上一次做了什么,这严重阻碍了交互式Web应用程序的实现。在典型的网上购物场景中,用户浏览了几个页面,买了一盒饼干和两瓶饮料。最后结帐时,由于HTTP的无状态性,不通过额外的手段,服务器并不知道用户到底买了什么,所以Cookie就是用来绕开HTTP的无状态性的“额外手段”之一。服务器可以设置或读取Cookies中包含信息,借此维护用户跟服务器会话中的状态。

在刚才的购物场景中,当用户选购了第一项商品,服务器在向用户发送网页的同时,还发送了一段Cookie,记录着那项商品的信息。当用户访问另一个页面,浏览器会把Cookie发送给服务器,于是服务器知道他之前选购了什么。用户继续选购饮料,服务器就在原来那段Cookie里追加新的商品信息。结帐时,服务器读取发送来的Cookie就行了。

Cookie另一个典型的应用是当登录一个网站时,网站往往会请求用户输入用户名和密码,并且用户可以勾选“下次自动登录”。如果勾选了,那么下次访问同一网站时,用户会发现没输入用户名和密码就已经登录了。这正是因为前一次登录时,服务器发送了包含登录凭据(用户名加密码的某种加密形式)的Cookie到用户的硬盘上。第二次登录时,如果该Cookie尚未到期,浏览器会发送该Cookie,服务器验证凭据,于是不必输入用户名和密码就让用户登录了。

用户可以改变浏览器的设置,以使用Cookies。同时一些浏览器自带或安装开发者工具包允许用户查看、修改或删除特定网站的Cookies信息。

如果在一台计算机中安装多个浏览器,每个浏览器都会以独立的空间存放Cookie。因为Cookie中不但可以确认用户信息,还能包含计算机和浏览器的信息,所以一个用户使用不同的浏览器登录或者用不同的计算机登录,都会得到不同的Cookie信息,另一方面,对于在同一台计算机上使用同一浏览器的多用户群,Cookie不会区分他们的身份,除非他们使用不同的用户名登录。

一些人反对Cookies在网络中的应用,他们的理由如下:

如果用户在获取了一个 Cookie 之后,点击了浏览器的"回退"按键,则浏览器的状态和获取Cookie 的状态就出现了不一致.例如, 如果网站基于 Cookie 技术实现了购物车的应用,当用户添加了物品后点击了"回退"按键, 购物车的物品状态可能并没有发生变化.

Cookies在某种程度上说已经严重危及用户的隐私和安全。其中的一种方法是:一些公司的高层人员为了某种目的(譬如市场调研)而访问了从未去过的网站(通过搜索引擎查到的),而这些网站包含了一种叫做网页臭虫的图片,该图片透明,且只有一个像素大小(以便隐藏),它们的作用是将所有访问过此页面的计算机写入Cookie。而后,电子商务网站将读取这些Cookie信息,并寻找写入这些Cookie的网站,随即发送包含了针对这个网站的相关产品广告的垃圾邮件给这些高级人员。

虽然Cookies没有中电脑病毒那么危险,但它仍包含了一些敏感消息:用户名、电脑名、使用的浏览器和曾经访问的网站。用户不希望这些内容泄漏出去,尤其是当其中还包含有私人信息的时候。

这并非危言耸听,跨网站脚本(Cross site scripting)可以达到此目的。在受到跨网站脚本攻击时,Cookie盗贼和Cookie毒药将窃取内容。一旦Cookie落入攻击者手中,它将会重现其价值。

鉴于Cookie的局限和反对者的声音,有如下一些替代方法:

相关

  • 全民健康保险全民健康保险,一般简称为“全民健保”或“健保”,是一种强制性保险的福利政策,法源是依据《中华民国宪法增修条文》所实施的全民医疗保险制度。为增进全体国民健康,中华民国于19
  • 暗沙暗沙指覆盖有碎屑沙粒的珊瑚礁体,在海平面以下,在较浅的位置(较深且表面平坦的称作暗滩,有时会露出水面者称暗礁)。在南海海域有大量的暗沙,如曾母暗沙、北康暗沙、南康暗沙等。
  • 苗瑶语苗瑶语是苗、瑶、畲等族群所使用的有共同来源的一些语言的总称。学术界对于苗瑶语的语言系属分类有不同看法:华人和中国学者多认为苗瑶语是属于汉藏语系的语族,即苗瑶语族;欧美
  • 车路士切尔西足球俱乐部(英语:Chelsea Football Club),是一间位于英格兰首都伦敦的足球俱乐部,目前比赛于英格兰超级联赛。球队主场为斯坦福桥球场。切尔西足球俱乐部成立至今超过一百
  • 桂柳战役桂柳战役,中国称为桂柳反攻作战。,于1945年4月至8月,中国第2、第3方面军在广西省龙州、南丹、全州、阳朔地区对日军第6方面军展开反攻作战。当时盟军已攻占硫磺岛及琉球群岛,日
  • 布良斯克布良斯克 (Брянск)是俄罗斯布良斯克州的州府,位于杰斯纳河 (第聂伯河支流)畔。面积186平方公里,2002年人口431,526人。
  • 盘盘泰国中部:泰国北部:泰国南部:盘盘国是3世纪-7世纪时马来半岛的一个古代国家,其地理位置在马来半岛东岸,暹罗湾附近,与狼牙脩国接壤,北接占城国、堕和罗国,东南接哥罗国。自交州海行
  • 早期尼德兰绘画早期尼德兰绘画也称佛兰芒原始绘画(荷兰语:Vlaamse Primitieven)是15及16世纪北方文艺复兴时勃艮第及哈布斯堡统治时的尼德兰地区的绘画作品,布鲁日、根特、图尔奈及布鲁塞尔是
  • 加利西亚王国加利西亚王国(加利西亚语:Reino de Galicia)是位于伊比利亚半岛西北部,西班牙加利西亚地区的一个王国。历史上曾有两个加利西亚王国。第一个加利西亚王国出现在罗马帝国灭亡之后
  • 2018年至2019年意大利足球甲级联赛 2018年至2019年意大利足球甲级联赛(意大利语:Serie A 2018-2019,受意大利移动电信赞助冠名为Serie A TIM 2018-2019)是意大利顶级联赛的第117个赛季。本赛季在2018年8月18