资讯专栏INFORMATION COLUMN

左手Cookie“小甜饼”,右手Web Storage

Nekron / 2622人阅读

摘要:源自阮一峰具体什么意思,请看下面的截图就一目了然表示对象的的数量实战网站名网站地址确认网站名查询机制原意是小甜饼,是服务器保存在浏览器的一小段文本信息,属于其中一种互联网存储机制。

目录 1. Web Storage 2. Cookie机制 3. 二者的联系与区别 1.Web Storage
1.1 概述

Web Storage是HTML5提供的一种新的浏览器端数据储存机制,它提供两种数据存储的对象:

localStorage:该对象存储的数据没有时间限制;

sessionStorage : 该对象存储的数据仅用于浏览器的一次对话,当对话结束(通常是窗口关闭),数据被清空;

1.2 特性

localStorage 和 sessionStorage对象都是构造函数Storage的实例,拥有同样的属性和方法,二者唯一的区别是存储数据的期限不一;

localStorage和sessionStorage这两个对象相较于cookie的存储机制,能够提供更大的数据存储空间,但是存储空间根据浏览器类型而定,一般Chrome是2.5MB、Firefox和Opera是5MB、IE是10MB;

目前现代浏览器均支持web存储,但IE 7-是不支持的,依旧采用传统的cookie保持信息;
检测浏览器是否支持web存储的方法有:

//method 1
window.localStorage && window.localStorage.getItem
//method 2
if (typeOf(Storage) !== "undefined"){
    //support Web Storage
}else{
}

使用Web Stroage的API进行数据存储是,只能存储为字符串数据,因此所以数据在写入时会隐式调用toString方法转换为字符串;

var data = {
  name:"teren",
  age:18
}
localStorage.setItem("data",data);
console.info(localStorage.data);
localStorage.setItem("realData",JSON.stringify(data));
console.info(localStorage.realData)

【注意事项】

使用前要判断浏览器是否支持Web Stroage(无痕模式和低版本的IE不支持);

超出存储容量的处理;

避免敏感信息存入Web Storage,要注意[XXS]()的注入风险

1.3 优势与局限性

优势

存储空间大:与cookie的4k存储空间相比,Web Storage虽然不同浏览器的标准可能不一样,主流的一般都在5~10M;

页面性能优化:本地存储的数据不会被发到服务器,与cookie相比,节省带宽,加快响应速度

接口更加易用

局限性

server端无法获取本地数据,如有需求,可通过post/get方法;

只能同源共享数据;

1.4 接口

由于localStorage和sessionStorage对象的属性和方法是基本一致,下面以localStorage为例,讲解一下localStorage对象的接口;

存储数据

//method 1
localStorage.setItem("key","value");
//method 2
localStorage.key = value

读取数据

//method 1
localStorage.getItem("key")
//method 2 
localStorage.key
localStorage.setItem("name","teren")
console.log(localStorage.name)
localStorage.age = 12
console.log(localStorage.age)
localStorage.getItem("name"

删除数据

//method 1 
localStorage.removeItem("key")//删除特定的key
//method 2
localStorage.clear()//删除所有的数据

获取特定索引的key

localStorage.key(index)

事件监听
当存储的数据发生变化时,会触发storage事件,我们可以通过以下代码了解storage的事件对象包含哪些属性

function setData(key,value){
  localStorage.setItem(key,value)
};
setData("name","teren")
setData("first","kobe")
window.addEventListener("storage",function(e){

  console.log(e.oldValue);
  console.log(e.newValue);
  console.log(e.url)
},false)

注意,该事件不在导致数据变化的当前页面触发。如果浏览器同时打开一个域名下面的多个页面,当其中的一个页面改变sessionStorage或localStorage的数据时,其他所有页面的storage事件会被触发,而原始页面并不触发storage事件。可以通过这种机制,实现多个窗口之间的通信。所有浏览器之中,只有IE浏览器除外,它会在所有页面触发storage事件。(源自阮一峰)

具体什么意思,请看下面的截图就一目了然:

localStorage.length表示localStorage对象的key的数量

1.5 实战
//html



  
  JS Bin


  网站名:
  
网站地址:

网站名:
//js (function(){ var confirm = document.getElementById("confirm") var search = document.getElementById("search") var website = document.getElementById("website") var url = document.getElementById("url") var list = document.getElementById("list") confirm.addEventListener("click",function(e){ localStorage.setItem("website",url.value) console.log(localStorage.website) }); search.addEventListener("click",function(e){ document.getElementById("list").innerHTML = localStorage.getItem("website") console.log(list,innerHTML) }); })();

demo

2.Cookie机制

Cookie原意是小甜饼,是服务器保存在浏览器的一小段文本信息,属于其中一种互联网存储机制。

2.1 Cookie特点

每个Cookie大小一般不超过4KB;

Cookie保存的信息包括Cookie名、Cookie值、到期时间、所属域名和生效路径;

浏览器每次向服务器发出请求,会在Http请求头上带上Cookie信息;

2.2 Cookie API

浏览器可以设置拒绝Cookie

window.navigator.cookieEnabled = false;

获取当前页面的所有Cookie

    var allCookies = document.cookie
    //document.cookie返回的是分号分隔的所有cookie,如要取得每个cookie的值,可使用
    var cookies = document.cookie.split(";");
    for (var i=0;i

写入Cookie

document.cookie =  "name=teren";
//document.cookie一次只能写一个cookie,而且是写入而不是覆盖;

[疑问]为什么读取cookie是全部,而写入则是一个一个呢?
这与浏览器和服务器之间的cookie通信格式相关。

浏览器向服务器发送cookie时,是将所有cookie一起发送;

GET /sample_page.html HTTP/1.1
Host: www.example.orgCookie: cookie_name1=cookie_value1; cookie_name2=cookie_value2Accept: */*

服务器告诉浏览器需要存储cookie时,则是分行设定

HTTP/1.0 200 OKContent-type: text/htmlSet-Cookie: cookie_name1=cookie_value1Set-Cookie: cookie_name2=cookie_value2; expires=Sun, 16 Jul 3567 06:23:41 GMT

删除cookie
删除cookie的简便方法就是设置expires = 0或者是过期时间,如expires = Thu,01-Jan-1970 00:00:01 GMT

cookie的属性

Set-Cookie: value[;expires = date][;domain = domain][;path = path][;secure][;HttpOnly]

value:规定cookie的值,形式是键值对;
expires:规定cookie过期时间,格式为形式为expires = someDate.toGMTString()
domain:指定cookie所在的域名,只有访问的域名匹配domain属性,cookie才会发送到服务器;
path:指定路径,只有path属性匹配向服务器发送的路径,cookie才会发送,只要path属性匹配发送路径的一部分,都可以发送;
secure:指定cookie只能在加密协议HTTPS下发送到服务器;
HttpOnly:设置cookie不能被js读取,这主要是放置XSS攻击盗取cookie;

一个完整的浏览器设置cookie写法:

document.cookie = "name=teren;"
+"expires = Thu,01-Jan-1970 00:00:01 GMT"
+"domain = terenyeung.com;"
+"path = /;"
+"secure;"
+"HttpOnly"
3.Web Storage和Cookie的联系与区别
特性 cookie Web Storag
数据生命周期 服务器生成的话,为指定失效时间;浏览器段生成的话默认为关闭浏览器后 localStorage永久有效,除非使用localStorage.clear()清空;sessionStorage为关闭浏览器后;
存储空间 一般为4K 一般5MB~10MB
与服务器通信 每次携带在HTTP头中 仅在客户端,如需通信,可通过get或post方法
应用场景 用户登录身份验证(结合HttpOnly相对安全性高) 保存用户购物车信息以及HTML5游戏的本地存储

参考资料

HTML5 Web 存储

八一下LocalStorage本地存储的卦——AlloyTeam

Web Storage API——MDN

Web Storage:浏览器端数据储存机制——阮一峰

Cookie——阮一峰

详说 Cookie, LocalStorage 与 SessionStorage

文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。

转载请注明本文地址:https://www.ucloud.cn/yun/86494.html

相关文章

  • 来聊一聊Cookie(甜饼),及其涉及到的web安全吧

    摘要:最近在用写自己的博客,发现总是掉到的坑,于是就好好八一八这个小甜饼,没想到居然还说很有意思的,每一个知识点都能拉出一条大鱼,想想自己之前对,简直就是它认识我,我只能叫出他的名字。 最近在用thinkjs写自己的博客,发现总是掉到cookie的坑,于是就好好八一八这个小甜饼,没想到居然还说很有意思的,每一个知识点都能拉出一条大鱼,想想自己之前对cookie,简直就是它认识我,我只能叫出他...

    Donne 评论0 收藏0
  • Web Storage相关

    摘要:当页面重新载入或者被恢复时,页面会话也是一直存在的。自动保存一个文本域中的内容,如果浏览器被意外刷新,则恢复该文本域中的内容,所以不会丢失任何输入的数据。该例中,我们测试数据项是否存在。 访问原文地址 概述 DOM存储的机制是通过存储字符串类型的键/值对,来提供一种安全的存取方式.这个附加功能的目标是提供一个全面的,可以用来创建交互式应用程序的方法(包括那些高级功能,例如可以离线工作一...

    kevin 评论0 收藏0
  • 详说 Cookie, LocalStorage 与 SessionStorage

    摘要:顾名思义,确实非常小,它的大小限制为左右,是网景公司的前雇员在年月的发明。是标准中新加入的技术,它并不是什么划时代的新东西。特性与的接口类似,但保存数据的生命周期与不同。但当页面关闭后,中的数据就会被清空。 本文最初发布于我的个人博客:咀嚼之味 最近在找暑期实习,其中百度、网易游戏、阿里的面试都问到一些关于HTML5的东西,问题大多是这样开头的:你用过什么HTML5的技术呀?...

    endless_road 评论0 收藏0

发表评论

0条评论

Nekron

|高级讲师

TA的文章

阅读更多
最新活动
阅读需要支付1元查看
<