经常使用的本地存储——cookie篇

1、引言

随着浏览器的处理能力不断加强,愈来愈多的网站开始考虑将数据存储在「客户端」,那就不得不谈谈本地存储了。本地存储的好处显而易见,一是避免取回数据前页面一片空白,若是不须要最新数据也能够减小向服务端请求的次数,从而减小用户等待从服务器获取数据的时间,二是网络状态不佳时仍能够显示离线数据html

下面来看看经常使用的本地存储。web

chrome浏览器打开一个网页,进入开发者模式,点击Resources,咱们能够看到:chrome

clipboard.png

以上的 indexedDBLocal StorageSession StorageCookies,就是经常使用的本地存储其中几种。下面咱们一一了解。数据库

2、经常使用的本地存储

一、cookie浏览器

HTTP cookie,一般直接叫作cookie,是客户端用来存储数据的一种选项,它既能够在客户端设置也能够在服务器端设置。cookie会跟随任意HTTP请求一块儿发送。安全

优势:兼容性好服务器

缺点:一是增长了网络流量;二则是它的数据容量有限,最多只能存储4KB的数据,浏览器之间各有不一样;三是不安全。 cookie

二、userData网络

userData是微软经过一个自定义行为引入的持久化用户数据的概念。用户数据容许每一个文档最多128KB数据,每一个域名最多1MB数据。session

缺点:userData不是 web 标准的一部分,只有IE支持

三、web存储机制

web storage,包括两种:sessionStoragelocalStorage,前者严格用于一个浏览器会话中存储数据,由于数据在浏览器关闭后会当即删除;后者则用于跨会话持久化地存储数据。

缺点:IE不支持 SessionStorage,低版本IE ( IE6, IE7 ) 不支持 LocalStorage,而且不支持查询语言

四、indexedDB

indexed Database API,简称为indexedDB,是在浏览器中保存结构化数据的一种「数据库」。它相似SQL数据库的结构化数据存储机制,代替了废弃已久的web SQL Database API,它可以在客户端存储大量的结构化数据,而且使用索引高效检索的API。

缺点:兼容性很差,未获得大部分浏览器的支持。

五、Flash cookie

Flash本地存储,相似于HTTP cookie,它是利用 SharedObject类来实现本地存储信息。它默认容许每一个站点存储不超过100K的数据,远大于cookie,并且可以跨浏览器。

缺点:浏览器需安装 Flash 控件,毕竟它是经过Flash的类来存储。所幸的是,没有安装Flash的用户极少。

六、Google Gears

Google Gears是Google在07年发布的一个开源浏览器插件,Gears 内置了一个基于SQLite的嵌入式 SQL数据库,并提供了统一API 对 数据库进行访问,在取得用户受权以后,每一个站点能够在SQL数据库中存储「不限大小」的数据。

缺点:须要安装 Google Gears 组件

下面将对 cookie 进行详细的介绍。

3、cookie的用途

3.1 概述

下面来详细谈谈cookie。

Cookie是一小段文本信息,伴随着用户请求在 Web 服务器和浏览器之间传递。它存储于访问者的计算机中,每当同一台计算机经过浏览器请求某个页面时,就会发送这个 cookie。

首先声明,它是「浏览器」提供的一种机制,它将 document 对象的 cookie 属性提供给 JavaScript。可使用JavaScript来建立和取回 cookie 的值,所以咱们能够经过document.cookie访问它。

cookie是存于用户硬盘的一个文件,这个文件一般对应于一个域名,也就是说,cookie能够跨越一个域名下的多个网页,但不能跨越多个域名使用。

3.2 cookie的用途及工做原理

那cookie具体能干什么呢?

cookie 将信息存储于用户硬盘,所以能够做为全局变量,这是它最大的一个优势。它最根本的用途是 Cookie 可以帮助 Web 站点保存有关访问者的信息,如下列举cookie的几种小用途。

  • 保存用户登陆信息。这应该是最经常使用的了。当您访问一个须要登陆的界面,例如微博、百度及一些论坛,在登陆事后通常都会有相似"下次自动登陆"的选项,勾选事后下次就不须要重复验证。这种就能够经过cookie保存用户的id。
  • 建立购物车。购物网站一般把已选物品保存在cookie中,这样能够实现不一样页面之间数据的同步(同一个域名下是能够共享cookie的),同时在提交订单的时候又会把这些cookie传到后台。
  • 跟踪用户行为。例如百度联盟会经过cookie记录用户的偏好信息,而后向用户推荐个性化推广信息,因此浏览其余网页的时候常常会发现旁边的小广告都是本身最近百度搜过的东西。这是能够禁用的,这也是cookie的缺点之一。

那么,cookie是怎么起做用的呢?

在上一节中咱们知道 cookie 是存在用户硬盘中,用户每次访问站点时,Web应用程序均可以读取 Cookie 包含的信息。当用户再次访问这个站点时,浏览器就会在本地硬盘上查找与该 URL 相关联的 Cookie。若是该 Cookie 存在,浏览器就将它添加到request headerCookie字段中,与http请求一块儿发送到该站点。

clipboard.png

要注意的是,添加到 request header 中是「浏览器的行为」,存储在cookie的数据「每次」都会被浏览器「自动」放在http请求中。所以,若是这些数据不是每次都要发给服务器的话,这样作无疑会增长网络流量,这也是cookie的缺点之一。为了不这点,咱们必须考虑什么样的数据才应该放在cookie中,而不是滥用cookie。每次请求都须要携带的信息,最典型的就是身份验证了,其余的大多信息都不适合放在cookie中。

4、cookie的格式

明白了工做原理后,接着咱们来看看cookie长什么样,而后再一步步深刻了解该怎么去用它。

那么,如何获取 cookie 呢?从第1小节了解到,浏览器提供了 cookie 属性给 JavaScript,所以能够经过 document.cookie 来访问这个页面中的cookie。

clipboard.png

这是一串字符串,仔细观察,咱们能够发现规律。每一个 cookie 都以名/值对的形式,即 name=value,名称和值都必须是URL编码的,且两对cookie间以分号和空格隔开。(ps:千万不要忘了空格,特别是在获取某个 cookie 时)

依旧是进入开发者模式,咱们来看下Resources下的Cookies

clipboard.png

红色标注的那行,稍微猜测一下,也能够知道它是与cookie相关的值和属性。name、value 没必要多说,天然是 cookie 的名和值。domainPathExpries/Max-agehttponly(即HTTP选项)、Secure 等均是 cookie 的属性,咱们一一了解下。

咱们先手动添加几个cookie,而后再来一一看下属性(具体设置cookie的方法在下一小节详解)。

代码以下:

document.cookie = "test1=myCookie1;"
document.cookie = "test2=myCookie2; domain=.google.com.hk; path=/webhp"
document.cookie = "test3=myCookie3; domain=.google.com.hk; expires=Sat, 04 Nov 2017 16:00:00 GMT; secure"
document.cookie = "test4=myCookie4; domain=.google.com.hk; max-age=10800;"

clipboard.png

4.1 domain和path

domain 和 path 这两个选项共同决定了cookie能被哪些页面共享。

clipboard.png

标红区域是默认状况,正如例1中未设置domain和path最终显示的状况。

domain 参数是用来控制 cookie对「哪一个域」有效,默认为设置 cookie的那个域。这个值能够包含子域,也能够不包含它。如上图的例子,Domain选项中,能够是".google.com.hk"(不包含子域,表示它对google.com.hk的全部子域都有效),也能够是"www.google.com.hk"(包含子域)。

path用来控制cookie发送的指定域的「路径」,默认为"/",表示指定域下的全部路径都能访问。它是在域名的基础下,指定能够访问的路径。例如cookie设置为"domain=.google.com.hk; path=/webhp",那么只有".google.com.hk/webhp"及"/webhp"下的任一子目录如"/webhp/aaa"或"/webhp/bbb"会发送cookie信息,而".google.com.hk"就不会发送,即便它们来自同一个域。

4.2 expries/max-age失效时间

expries 和 max-age 是用来决定cookie的生命周期的,也就是cookie什么时候会被删除。

clipboard.png

标红区域为默认状况,即Session,表示浏览器会话结束时(即关闭浏览器)就会删除cookie。

固然,用户也能够经过expries设置删除时间。这个值是个GMT格式的日期,相似例三中的Sat, 04 Nov 2017 16:00:00 GMT,这代表这个 cookie 将在2017-11-04的16时整失效,在此期间浏览器关闭后此cookie仍会保存在用户的机器中。GMT格式能够经过 toGMTString()toUTCString() 得到。若是设置的失效时间是个之前的时间,则 cookie 会被当即删除,这也是用来删除 cookie 的方法。

在新的http协议中已经使用 max-age 属性来取代 expries。expries 表示的是失效时间,准确讲是「时刻」,max-age表示的是生效的「时间段」,以「秒」为单位。若 max-age 为正值,则表示 cookie 会在 max-age 秒后失效。如例四中设置"max-age=10800;",也就是生效时间是3个小时,那么 cookie 将在三小时后失效。若 max-age 为负值,则cookie将在浏览器会话结束后失效,即 session,max-age的默认值为-1。若 max-age 为0,则表示删除cookie。

4.3 secure

secure是 cookie 的安全标志,经过cookie直接包含一个secure单词来指定,也是cookie中惟一一个非名值对儿的部分。指定后,cookie只有在使用SSL链接(如HTTPS请求)时才会发送到服务器。

默认状况为空,不指定 secure 选项,即不管是 http 请求仍是 https 请求,均会发送cookie。

clipboard.png

标红区域为指定 secure 后的状况,同时也说明指定 secure 后 cookie 仍可见。

注意:只有保证网页是https协议(或其余安全协议)请求的,才能客户端在客户端经过 js 去设置secure 类型的 cookie。

4.4 httponly

httponly属性是用来限制客户端脚本对cookie的访问。将 cookie 设置成 httponly 能够减轻xss攻击的危害,防止cookie被窃取,以加强cookie的安全性。(因为cookie中可能存放身份验证信息,放在cookie中容易泄露)

HTTP那列用来表示是否设置了httponly属性,若设置了httponly,则会打勾(即标红区域)

clipboard.png

clipboard.png

咱们用 js 获取下cookie,能够发现访问不到 NID 这个cookie,说明js是没法读取和修改 httponly cookies,固然也不能设置 cookie 为 httponly,这只能经过服务器端去设置。

默认状况是不指定 httponly,便可以经过 js 去访问。

5、设置cookie

将 cookie 的属性介绍后,下一步就该谈谈如何利用这些属性去设置 cookie 了~

5.1 服务器端设置

服务器经过发送一个名为 Set-Cookie 的HTTP头来建立一个cookie,做为 Response Headers 的一部分。以下图所示,每一个Set-Cookie 表示一个 cookie(若是有多个cookie,需写多个Set-Cookie),每一个属性也是以名/值对的形式(除了secure),属性间以分号加空格隔开。格式以下:

Set-Cookie: name=value[; expires=GMTDate][; domain=domain][; path=path][; secure]

只有cookie的名字和值是必需的。

clipboard.png

注意,经过 Set-Cookie 指定的可选项(域、路径、失效时间、secure标志)只会在「浏览器端」使用,它们都是服务器给浏览器的指示,以指定什么时候应该发送cookie。这些参数不会被发送至服务器端,只有name和value才会被发送。

5.2 客户端设置

客户端设置cookie的格式和Set-Cookie头中使用的格式同样。以下:

document.cookie = "name=value[; expires=GMTDate][; domain=domain][; path=path][; secure]"

能够参照第3小节的四个例子测试下。

document.cookie = "test1=myCookie1;"
document.cookie = "test2=myCookie2; domain=.google.com.hk; path=/webhp"
document.cookie = "test3=myCookie3; domain=.google.com.hk; expires=Sat, 04 Nov 2017 16:00:00 GMT; secure"
document.cookie = "test4=myCookie4; domain=.google.com.hk; max-age=10800;"

若想要添加多个cookie,只能重复执行 document.cookie(如上)。这可能和平时写的 js 不太同样,通常重复赋值是会覆盖的,但对于cookie,重复执行 document.cookie 并「不覆盖」,而是「添加」(针对「不一样名」的)。

5.3 cookie的修改

上一节的最后是否有些疑惑?针对不一样名的cookie,执行document.cookie是添加,那「同名」的呢?实地演练一下~

以下图,咱们以test1做为实例试验下。

clipboard.png

再执行次 document.cookie = "test1=newCookie;"

clipboard.png

咱们发现,原来值为myCookie1的cookie不见了,test1原来的值myCookie1newCookie覆盖了,这也是这章要讲解的,修改cookie的方法。还没结束哦,咱们再试下能不能修改参数。

document.cookie = "test1=newCookie; max-age=3600; secure"

clipboard.png

如上图,咱们成功更改了名为test1的cookie的过时时间及安全标志。

document.cookie = "test1=newCookie; domain=.google.com.hk; max-age=3600; secure"
document.cookie = "test1=newCookie; path=/webhp; max-age=3600; secure"

clipboard.png

咱们发现没有覆盖原来的cookie,而是新增了cookie。这也是修改cookie时须要注意的地方,能够修改原cookie的expries、secure属性,但不能修改domain、path属性。修改cookie时domain、path必须与原cookie保持一致。

5.4 cookie的删除

cookie的删除其实特别简单,也是对此cookie从新赋值,上面介绍expriesmax-age时也有提到,将expries设为一个过去的时间或将max-age设为0,均可以删除cookie。同时也要特别注意此cookie的domain、path要与原来保持一致。

6、cookie编码

若 cookie 的名或值中包含分号、逗号和空格这三个特殊字符,那么它须要通过URL编码。通常可使用encodeURIComponent进行编码,它对应的解码函数是decodeURIComponent。若要给 cookie 指定额外的信息,只要将参数追加到该字符串(以下例)。

document.cookie = encodeURIComponent("test") + "=" + encodeURIComponent("myCookie") + "; max-age=3600";

7、cookie的缺点

  • 安全性:因为cookie在HTTP中是明文传递的,其中包含的数据均可以被他人访问,可能会被篡改、盗用。
  • 大小限制:cookie的大小限制在4KB左右,若要作大量存储显然不是理想的选择。
  • 增长流量:cookie每次请求都会被自动添加到Request Header中,无形中增长了流量。cookie信息越大,对服务器请求的时间也越长。

所以要慎用cookie,不要在cookie中存储重要和敏感的数据。

8、结语

关于 cookie 的部分就先聊到这啦~有不对的地方欢迎指正~

参考资料:

相关文章
相关标签/搜索