cookie和本地存储

Cookie(会话跟踪技术)

是存储在浏览器中的缓存信息,Cookie是开发人员如今可以使用的最古老、最稳定的客户端存储形式,由W3C组织提出最早由Netscape社区发展的一种机制,由于HTTP是一种无状态的协议,服务器单从网络连接上无从知道客户身份。

Cookie特性

  • 可以跨域同域名下的多个网页,但不能跨域多个域名使用
  • 存储空间限制允许4kb
  • 默认情况下,浏览器没有限制可以拥有的Cookie数量(不同浏览器会有不同)
  • 可以设置cookie过期时间

Cookie作用

实现客户端与服务器之间状态的保持

  • 登录记录
  • 多个页面的数据传递
  • 保存用户信息

Cookie查看

document.cookie //返回cookie信息
也可以在Application -> storage -> Cookies

Cookie使用方法

key=value键值对;

document.cookie = "name=mingxin"; //会在原有的cookie后面追加而不会被覆盖
document.cookie= "name=mingxin,age=18";//设置多个cookie使用 ;隔开

默认cookie的结束时间是关闭浏览器的时候

cookie不能识别中文需要转码

encodeURICompoent( string ) 将中文编译成对应的字符

decodeURICompoent( encodeURICompoent( string ) ) 将对应的字符转为中文

设置cookie常用属性

属性 描述
name 该Cookie的名称。Cookie一旦创建,名称便不可更改
value 该Cookie的值。如果值为Unicode字符,需要为字符编码。
expires 设置cookie的过期时间使用expires(确定的时间)
maxAge max-age用秒来设置cookie的生存期(5*24*60*60)
path 允许Cookie的使用路径
domain 可以访问该Cookie的域名。
secure 该Cookie是否仅被使用安全协议传输。安全协议。默认为false<br />如果不设置字段 cookie 可以通过http,https 协议加载设置<br />如果设置这个字段, 那么只能通过https协议才能设置成
HTTP-Only HTTP-Only 背后的意思是告之浏览器该 cookie 绝不能通过 JavaScript 的 document.cookie属性访问

设置单个Cookie过期时间

以天为过期时间单位设置cookie

setDate() 设置一个月的某一天

getDate() 返回当前多少号(1~31)

toGMTString() 把 Date 对象转换为字符串

getTime() 返回1970/1/1至今的毫秒数

1000 * 60 * 60 * 24*day //得到天的毫秒数

  • 方法一

    function setCookie(name,value,day){ 
        let date = new Date(); 
        data.setDate(date.getData()+day); //Mon Dec 14 2020 16:50:34 GMT+0800 (中国标准时间)
        //let expires= date.toGMTString(); //Mon, 14 Dec 2020 08:50:34 GMT
      let reg = new RegExp("[\\u4E00-\\u9FFF]+","g");
        if(reg.test(value)) encodeURIComponent(valu);
        document.cookie = `${name}=${value},expires=${date}`;
    }
    setCookie("name","mingxin",1)
    
  • 方法二

    function setCookie(name,value,day){
        let date = new Date().getTime();
        let ms = day * 24 * 60 * 60 * 1000;
        let newTime = date + ms;
        let newDate = new Date(newTime);
        document.cookie=`${name}=${value};expires=${newDate}`;
    }
    setCookie("name","value",2)
    
  • 简化方法

    function setCookie(obj){
        let date = new Date().getTime() + obj.day*24*60*60*1000;
        let newDate = new Date(date);
        document.cookie=`${obj.prop}=${obj.value};expires=${newDate};`
    }
    setCookie({ prop:"username",
              value:"mingxin",
              day:1})
    
  • 添加可选参数

    function setCookie(name,value,{expires,path,domain}={}){
        let cookieStr=encodeURIComponent(name)+"="+encodeURIComponent(value);
        if(expires){
            cookieStr += ";expires=" + expiresDate(expires);
        }
        if(path){
            cookieStr += ";path=" + path;
        }
    }
    //过期时间函数
    function expiresDate(day){
        let newDate = new Date(new Date().getTime() + day*24*60*60*1000);
        return newDate
    };
    //
    setCookie("username","pwd123456",{expires:1,......})
    

设置的过期时间不能小于当前时间 否则cookie会理解被清除

设置多个cookie

function setCookie(data){
    data.forEach((item,index)=>{
        var date = new Date(new Date().getTime() + item.time*24*60*60*1000);
        document.cookie = `${item.name }=${item.value};expires=${date}`;
    })
}
setCookie([
    {
        name:'w',
        value:18,
        time:1
    },{
        name:'h',
        value:19,
        time:2
    },{
        name:'d',
        value:20,
        time:3
    }
])

获取cookie

function getCookie(){
    let cookies= document.cookie; 
    let cookiesArr=cookies.split(";")
}               

二.WEB存储

本地存储
优点 离线应用程序<br />直接访问数据<br />节省网络流量<br />服务器获取数据
缺点 没有任何同步支持<br />存储限制模糊
Storage:

是HTML5中新增的特性用来解决cookie存储空间不足的问题,Cookie存储的进化版,存储的值限定字符串需要通过JSON对象去转换,存储内容多的话会消化内容空间, IE8以下不兼容;

分为两个:

本地存储(localStorage):

1.特点域内安全

2.数据多页面共享、

3.存储量限制5M-10M

4.会持久存在(除非被用户清除)

会话存储(sessionStorage) :

1.临时会话,刷新不会消失,只要浏览器关闭就会消失

2.数据不能共享

API口诀:"两个接口,四个函数“

两个接口:sessionStorage localStorage

四个函数:setItem getItem removeItem clear

设置setItem()(键名,键值):

(key,value)类型都是字符串

localStorage.setItem("name","mingxin"); //内置对象  
//设置中文转码encodeURIComponent("名");
获取getItem():

读取已经存储在本地的数据,通过key作为参数夺取出对应key的数据

let data = localStorage.getItem("name");
移除removeItem():

移除已经存储在本地的数据,通过key作为参数删除对应key的数据

localStorage.removeItem("name");
移除本地所有数据getItem():
localStorage.clear();

传入一个对象

let obj = {
    name:"mingxin",
    age:18,
    random:Math.florr(Math.random()*50)
}
localStorage.setItem("name",JSON.stringify(obj))
//获取
JSON.parse(localStorage.getItem("name"));

存储事件

当数据有修改或删除的情况下,就会触发storage事件

<span style="color:red">在对数据进行改变的窗口对象上是不会触发的(旧页面和新页面)</span>

storage对象常用属性:
key 修改或删除的key值,如果调用clear(),key为null
oldValue 改变前的value值
newValue 新设置的值(改变后的值),如果调用removeStorage(),key为null
storageArea 当前的storage对象
url 触发该脚本变化的文档的url(旧页面的url)
注:session同窗口才可以,例子:iframe操作

npm 里有封装好的库

window.addEventListener('storage',function(ev){
    console.log(ev.key);
    console.log(ev.newValue  );
    console.log(ev.oldValue );
    console.log(ev.storageArea );
    console.log(ev.url);
})

兼容问题

在老版本浏览器上,通过使用Cookies来做替代方案并做好域内安全。

三.离线存储(offline application)

​ HTML5 中可以让我们构建一个离线缓存的应用,离线存储是一个基于manifest文件(缓存清单文件,后缀名为.appcache/.manifest)的缓存机制,通过这个文件上的清单解析离线存储资源,这些资源就会像cookie一样被存储下来。之后当网络在处于离线状态时,浏览器就会通过被离线存储的数据进行页面展示,可以让我们构建一个离线缓存的应用。 cache缓存 manifest显示

离线缓存的优势:

1.可以配置需要缓存的资源

2.网络无连接应用扔可用

3.本地读取缓存资源,可以提升访问速度, 增强用户体验

4.减少请求,缓解服务器负担

缓存清单

缓存清单就是一个普通的文件,其中列出浏览器应该缓存的资源,以供离线的时候访问,一般使用.appcache/.manifest为后缀名。

缓存的使用 注:需结合服务器使用(常用服务器:IIS nginx apache)

html标签里使用缓存清单

<html lang="en" manifest="XXXXXX.manifest"> 

<html lang="en" manifest="XXXXXX.appcache"> 
缓存清单格式
  1. 顶行写 CACHE MANIFEST
  2. CACHE: 指定我们需要缓存的静态资源, 入css, image, js等
  3. NETWORK: (可选) 指定需要在线访问的资源, 可以使用通配符--无论缓存中是否存在,均从网络获取
  4. FALLBACK: (可选) 当被缓存的文件找不到时的备用资源
CACHAE MANIFEST //顶行

CACHE: //需要缓存哪些资源
./image/one.jpg
./image/two.jpg
./image/three.jpg

NETWORK:  //指定需要在线访问的资源
*   //*代表所有没有确定缓存的资源都不进行缓存

FALLBACK:  //当被缓存的文件找不到时的备用资源
./image/four.jpg    ./image/five.jpg    //当four.jpg缓存资源丢失找不到-->启用备份five.jpg

可在浏览器Application-->Cache-->Application Cache 查看缓存

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

推荐阅读更多精彩内容