JS的cookie与sessionStorage和localStorage

本文详细介绍了HTTP Cookie技术,包括其特点、使用场景及安全性问题。同时,对比了Cookie与WebStorage(sessionStorage和localStorage)的异同,强调了WebStorage在数据存储和操作上的便利性。此外,还探讨了它们在登录认证、购物车、简单数据存储等场景的应用,并提到了解决无状态HTTP的问题,如使用session和token。最后,列举了localStorage和sessionStorage的关键API,用于数据的增删查改。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

cookie

基于http协议的一种本地'存储'技术 (它就相当于钱包)

document.cookie="username=itzan; expires=有效时间 GMT; path=/";domain=;secure;

它的特点:

1.基于http协议 2.它会随着请求携带到服务器 3.只能存储4k左右 4.能跨域(设置domain),默认不可以 5.容易被伪造,不安全,会造成 xss攻击 (站点伪造)

它的使用场景:

1.免登录 2.购物车 3.简单的存储,非铭感数据

http协议

常见于 浏览器与服务器的通信,它是属于 应用层 (应用程序) http 默认的端口是80 http协议的特点 短连接(断开式) 浏览器向服务器发送请求,服务器接受,并响应 无状态 不知道是谁访问了服务器,

  1. 用(cookie+session)解决

  2. token 凭证

cookie 、sessionStorage与localStorage的区别

特性sessionStoragelocalStorage
数据的生命期一般由服务器生成,可设置失效时间。如果在浏览器端生成Cookie,默认是关闭浏览器后失效仅在当前会话下有效,关闭页面或浏览器后被清除除非被清除,否则永久保存
存放数据大小4K左右一般为5MB一般为5MB
与服务器端通信每次都会携带在HTTP头中,如果使用cookie保存过多数据会带来性能问题仅在客户端(即浏览器)中保存,不参与和服务器的通信仅在客户端(即浏览器)中保存,不参与和服务器的通信
易用性需要程序员自己封装,源生的Cookie接口不友好源生接口可以接受,亦可再次封装来对Object和Array有更好的支持源生接口可以接受,亦可再次封装来对Object和Array有更好的支持

WebStorage(sessionStorage与localStorage)提供了一些方法,数据操作比cookie方便;

1).setItem (key, value) —— 保存数据,以键值对的方式储存信息。 2).getItem (key) —— 获取数据,将键值传入,即可获取到对应的value值。 3).removeItem (key) —— 删除单个数据,根据键值移除对应的信息。 4).clear () —— 删除所有的数据 5).key (index) —— 获取某个索引的key

//本地缓存

        //setItem 设置元素 key value

        //getItem 获取元素 通过key 来获取value

        //removeItem 移除元素根据key删除

        localStorage.setItem('username','jack')

        localStorage.getItem('username')

        //localStorage.removeItem('username')

        console.log( localStorage.getItem('username'));

   

        sessionStorage.setItem('password','123')

        sessionStorage.getItem('password')

        //sessionStorage.removeItem('password')

        //localStorage和cookie的区别

        //localStorage储存大小为5MB cookie只有4kb

        //cookie 会随着请求发送

        //cookie可以跨域 localStorage不行

        //cookie 能跨域(设置domain)

        //两者存储的位置不同

        //共同点

            //都只能储存字符串

            //都是位于浏览器上面

评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值