分享
 
 
 

四种有能力取代Cookies的客户端Web存储方案

王朝学院·作者佚名  2016-04-30
窄屏简体版  字體: |||超大  

目前在用户的网络浏览器中保存大量数据需要遵循几大现有标准,每一种标准都拥有自己的优势、短板、独特的W3C标准化状态以及浏览器支持级别。但无论如何,这些标准的实际表现都优于广泛存在的cookies机制。

今天的Web应用程序开始在客户端中执行大量数据处理工作,甚至可能需要以脱机方式完成任务。可以说,客户端数据存储对于下一代Web应用程序的发展起到了至关重要的作用。

然而直到现在,cookies仍然是用户浏览器中最常见的数据存储机制。如果一款Web应用需要重复访问某些数据,则只有两种方式可供选择:要么再次向服务器发送请求以获取数据,要么读取保存在cookies中的内容。

cookies机制只能提供有限的存储空间——最多4K或者4096字节——因此总量较大的数据会被拆分成4K大小的块从而加以明确而直接地管理。

但这种方式对于存储的协作及管理而言显然并不可行,因此我们需要拿出一套新的替代性方案。

cookies的承受能力太过孱弱

网络浏览器最初只是通过HTTP并解析HTML实现应用程序对文档内容的加载。但在此后不久,第一款网景浏览器出现了,它满足了用户的一系列实际需求,但却需要利用本质上无状态的HTTP协议来通过某些机制实现状态追踪。面对这一问题,Lou Montulli于1994年创造了浏览器cookie(当初被称为‘magic cookie’),并首次亮相于Mosiac网景浏览器0.9b版本之上。

在通用网关接口(简称CGI)提供的服务器端脚本访问功能与cookies的共同辅助下,最早的Web应用程序终于变成现实。最终,我们开始沿着这条小路将浏览器转化成为一种通用的应用程序平台。

然而cookies机制存在着严重缺陷。正如前面所提到,它只能存储极少量数据,而且很容易受到各类攻击活动的影响,这样的状况让我们很难利用其存储个人信息及敏感数据、从而极大限制了它的使用范围。

cookies会介入到从浏览器发向服务器端的每一条HTTP请求当中。假设一个网页中包含的四张图片、一个外部CSS文档外加javaScript文档。系统会为该域设置一个4K的cookie,浏览器则分四次将该cookie转发至服务器端——一次针对HTML页面、一次针对每张图片、一次针对CSS文档再加上一次针对Javascript文档。

令问题进一步复杂化的原因在于,这个理论上为4K大小的cookie需要从浏览器端传输至服务器端;由于大部分用户使用的是异步互联网连接,即上传速度低于下载速度,因此在HTTP响应头中传输cookie数据一定会造成不必要的带宽占用。

由于上述限制因素的存在,大部分cookies的体积都要远小于4K。谷歌建议每个cookie的实际大小不要超过400字节(或者200个字符),从而实现最佳性能表现。他们还建议称,在图片、CSS以及JavaScript等来自独特域的静态文件应该禁用cookies机制。

由于cookies机制在本地存储领域存在诸多问题,目前已经出现一系列新兴方案,旨在拨乱反正、保质保量完成任务。近几个月以来,已经有两款方案走上正轨、得到W3C的强烈推荐——它们能够很好、甚至比我们预想中更好地帮助浏览器支持本地存储功能。

目前我们可以从四种主流客户端数据存储机制中做出选择,它们分别是:Web SQL、IndexedDB、Web Storage以及application Cache。下面我们就逐一对每套方案加以评述,并探讨它们在运作及效果方面的各自特性。

Web SQL: 擅长(但是否有些过时?)数据库创建与执行

Web SQL是一种利用数据库进行数据存储并利用SQL处理检索任务的API。最近,Safari、Chrome以及Opera等知名浏览器纷纷在Web SQL与IndexedDB的竞争之中选择了前者。不过2010年时,SQLite还是惟一一款能够与Web SQL协作的数据库,而W3C出于安装基础较小的理由而停止对这套方案进行支持。

Web SQL的工作机制相当新奇,下面我们就一起来看示例代码。

Web SQL数据库的使用感受与关系类数据库及SQL非常相似。使用这款数据库的第一步在于创建并打开。如果大家不希望额外创建一套数据库,那么完全可以直接开始使用,API本身会自动完成创建工作。

下面我们来看一部分用于数据库创建的代码:

var db = openDatabase('cats', '1.0', 'a catalog of my cats', 2 *1024 * 1024);

按照从左到右的顺序,openDatabase后面的参数依次代表着数据库名称、版本号、文字说明以及预计数据库大小。

数据库创建完成之后,大家就可以着手使用了。在WebSQL数据库上执行SQL与创建事务对象并加以执行一样简单:

db.transaction(function (tx) { tx.executeSql('CREATE TABLE cats (id unique, name)'); tx.executeSql('INSERT INTO cats (id,name) VALUES (1,"Mr. Jones")'); });

尽管Safari、Chrome、Opera以及Mobile Safari都支持这款API,但自2010年以来Web SQL就没有发生过任何变化,因此它不太可能成为本地存储的新型标准。

Web Storage: 取cookies所长、去cookies所短

Web Storage利用一种简单的方法在用户的浏览器中存储键/值对。但它与cookies之间的相似之处也就仅此而已了。

•Web Storage是一套持久性方案。一旦某个值被存储之后就不会再消失或者终止,除非被应用程序或用户明确删除。

•Web Storage能够处理大量数据。目前浏览器的总体存储区域大小最高为5MB。

•Web Storage无需依赖于服务器,而且不必向服务器端发送数据。当然,大家可以随意实现本地化数据存储并将其与服务器进行异步式同步,但Web Storage的表现始终出色而且在离线与在线状况下都能正常生效。

•Web Storage提供四种主要方法——getItem(键);setItem(键、值);removeItem(键)以及clear()。

 
 
 
免责声明:本文为网络用户发布,其观点仅代表作者个人观点,与本站无关,本站仅提供信息存储服务。文中陈述内容未经本站证实,其真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
2023年上半年GDP全球前十五强
 百态   2023-10-24
美众议院议长启动对拜登的弹劾调查
 百态   2023-09-13
上海、济南、武汉等多地出现不明坠落物
 探索   2023-09-06
印度或要将国名改为“巴拉特”
 百态   2023-09-06
男子为女友送行,买票不登机被捕
 百态   2023-08-20
手机地震预警功能怎么开?
 干货   2023-08-06
女子4年卖2套房花700多万做美容:不但没变美脸,面部还出现变形
 百态   2023-08-04
住户一楼被水淹 还冲来8头猪
 百态   2023-07-31
女子体内爬出大量瓜子状活虫
 百态   2023-07-25
地球连续35年收到神秘规律性信号,网友:不要回答!
 探索   2023-07-21
全球镓价格本周大涨27%
 探索   2023-07-09
钱都流向了那些不缺钱的人,苦都留给了能吃苦的人
 探索   2023-07-02
倩女手游刀客魅者强控制(强混乱强眩晕强睡眠)和对应控制抗性的关系
 百态   2020-08-20
美国5月9日最新疫情:美国确诊人数突破131万
 百态   2020-05-09
荷兰政府宣布将集体辞职
 干货   2020-04-30
倩女幽魂手游师徒任务情义春秋猜成语答案逍遥观:鹏程万里
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案神机营:射石饮羽
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案昆仑山:拔刀相助
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案天工阁:鬼斧神工
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案丝路古道:单枪匹马
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:与虎谋皮
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:李代桃僵
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:指鹿为马
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案金陵:小鸟依人
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案金陵:千金买邻
 干货   2019-11-12
 
推荐阅读
 
 
 
>>返回首頁<<
 
靜靜地坐在廢墟上,四周的荒凉一望無際,忽然覺得,淒涼也很美
© 2005- 王朝網路 版權所有