cookies&session

诞生

  • 由于HTTP协议是无状态的协议,一旦数据交换完毕,客户端与服务器端的连接就会关闭,再次交换数据需要建立新的连接。这就意味着服务器无法从连接上跟踪会话。于是需要引入一种机制,COOKIE于是就顺应而生。
  • Session是另一种记录客户状态的机制,不同的是Cookie保存在客户端浏览器中,而Session保存在服务器上。客户端浏览器访问服务器的时候,服务器把客户端信息以某种形式记录在服务器上。这就是Session。

区别

  • cookie数据存放在浏览器中,而Session数据放在服务器中
  • cookie一般存放的少量且不重要的数据,Session中可以存放较多的数据。
  • cookie中存放的字符串,session中可以存放任何对象

cookie&sessionStorage&localStorage

他们都是保存在浏览器端的,且是同

比较

cookie和local Storage

  • cookies支持的数据内容小,一般8K左右;local Storage能支持到10M左右;
  • cookies不能进行跨域访问,作为HTTP请求的一部分,会增加带宽
  • local Storage本地化持久化
  • web Storage拥有setItem,getItem,removeItem,clear等方法,不需要cookies那样,自己进行封装

session Storage和local Storage

  • local Storage适用于长期存储数据,浏览器关闭之后数据不丢失
  • session Storage存储的数据在浏览器关闭之后自动删除

cookies和sessionStorage和localStorage

  • cookies数据始终在同源的HTTP请求中携带;而后两者不会自动把数据发给服务器,仅在本地保存
  • cookies还有路径的概念,可以限制只属于某个路径下

#HTML5离线存储

两种方式:

  • HTML5的离线存储.appcache文件(废弃)
  • service-work 的标准

强缓存&协商缓存

由于服务器端的资源不是一直固定不变的,会不时的进行更新,所以此时依旧访问本地缓存的话,对于用户来说看到的还是旧的资源,相当于没有进行过更新。所以我们希望当服务器更新了资源就向服务器请求新资源,没有更新就使用本地缓存,最大程度减少因网络请求而带来的资源浪费。

Session缓存好还是redis好_服务器