科百科
当前位置: 首页 范文大全

怎样清浏览器的缓存(说说浏览器有哪些缓存)

时间:2023-05-25 作者: 小编 阅读量: 2 栏目名: 范文大全

indexDB设计的操作完全是异步进行的。indexDB最大的特色是使用对象保存数据。cookies的基本思想就是让浏览器积累一组服务器特有的信息,并在客户端和服务器端来回传递。Cookies一般存在用户本地终端上,通常经过加密处理。Cookies一般通过http请求中的头部一起发送到服务器端。一条cookie记录主要由键、值、域、过期时间、大小组成。这两个都是windows对象的属性。不同的浏览器无法共享localStorage或sessionStorage中的信息。

一. 什么是缓存

web缓存是一个设备,这个设备可以自动保存常用的文档的副本。在客户端发起请求的时候,如果就近的缓存拥有客户端想要的副本,那么就会加快网站的响应速度。

在出现带宽不足、瞬间拥塞(很多用户同时访问某一站点)、距离时延(由于距离很远产生时延)这些情况下,缓存的优势就会体现出来了。

缓存可分为:私有缓存和公有缓存

私有缓存是个人缓存,包含单个用户最常用的页面。(浏览器的缓存是私有缓存)

公有缓存包含了某个用户团体的常用的页面。

二. 浏览器存储

浏览器存储(Browser Caching)是浏览器的一种优化机制。浏览器的缓存中保存了用户经常访问的一些文档的副本,避免了一些重复的网络请求,

浏览器能够快速地读取本地的数据,这样就会加快网站的访问速度。

1. 浏览器有哪几种缓存机制

浏览器一共有九种缓存机制

打开浏览器 -> 点击F12 -> 点Application

可以看到浏览器的多种缓存机制:

浏览器的几种缓存机制

(1). http缓存

http缓存是基于http协议的浏览器文件缓存机制,当重复请求某一个文件时,浏览器可以根据协议的头文件判断是从服务器端请求文件还是从本地读取文件。

上图中的Frames展示的就是http缓存

a. 判断过期的两种方式:

ExpiresCache-Control:max-age

Expires:存的是绝对的过期的日期(例如:牛奶的保质期)

Cache-Control:max-age 存的是还可以保鲜多久,是相对时间,用秒做单位

b. 如果a中判断缓存已经过期,那么就要进行缓存再验证

缓存再验证的两种方式:

请求报文里携带

If-Modified-Since:Date和If-None-Match

If-Modified-Since:Date 对修改日期进行验证

If-None-Match:<tags> 对实体标签的版本标识符进行验证

例如:

响应报文:

HTTP/1.1 200 OKLast-Modified: Tue, 12 Dec 2006 03:03:59 GMTETag: "10c24bc-4ab-457e1c1f"Content-Length: 12195

下一次的请求报文 :

GET /i/yahoo.gif HTTP/1.1Host: us.yimg.comIf-Modified-Since: Tue, 12 Dec 2006 03:03:59 GMTIf-None-Match: "10c24bc-4ab-457e1c1f"

再次响应的报文:

HTTP/1.1 304 Not Modified

c. b中再验证的结果有两种:服务器中的文件未修改 和 服务器中的文件有修改

服务器中的文件未修改:缓存中的副本可以使用,那么浏览器直接从缓存读取文档,返回304

服务器中的文件有修改:缓存中的副本不能使用,那么直接从服务器端读取文档,返回200

(2). indexDB 客户端本地数据库(大型数据库)

indexDB是浏览器中的一种数据库,用来保存结构化数据。

indexDB设计的操作完全是异步进行的。

indexDB最大的特色是使用对象保存数据。

indexDB.open(“database”) 打开数据库 或者 创建并打开数据库;

indexDB.setVersion(“1.0”) 为数据库指定一个版本号;

database.transaction(); 创建事务,对数据库进行操作;

openCursor() 在对象存储空间上调用这个方法,通过游标查找数据;

createIndex() 创建索引;

indexDB的并发问题;

(3). Cookies

1.cookies是什么

cookies是服务器用来标识web用户的一小块数据。

cookies的基本思想就是让浏览器积累一组服务器特有的信息,并在客户端和服务器端来回传递

Cookies是由服务器端生成,发送给浏览器,浏览器会将Cookies的key/value保存到某个目录下的文本文件内,

下次请求同一网站时就发送该Cookies给服务器(前提是浏览器设置为启用cookies)。

Cookies一般存在用户本地终端上,通常经过加密处理。

Cookies一般通过http请求中的头部一起发送到服务器端。在客户端和服务器端之间来回传递。

一条cookie记录主要由键、值、域、过期时间、大小组成。

2. cookies的分类:持久cookies 和 会话cookies

一般而言,我们所说的cookie是指的持久cookie(设置了过期时间的cookie)

持久cookie:存储在硬盘上;

持久cookie:是在过期时间之后消失。

持久cookie:是存在电脑硬盘里,是可以被同一个浏览器的所有页面共享的(无论是多进程还是多线程浏览器);

补充一点点:

不同浏览器之间不能共享cookie,因为每个浏览器存cookie路径不是一样的。

3. cookies的安全性问题:

第三方web站点使用持久cookie来跟踪用户,当用户访问同一个广告公司提供的站点,浏览器就会回送之前设置的持久cookie,

广告公司便可构建成一个用户档案和浏览习惯的详尽数据集。

(4). storage类型

有如下方法:

clear();

getItem(name);

key(index);

removeItem(name);

setItem(name,value);

localStorage对象:要访问同一个localStorage对象,页面必须同源;

sessionstorage对象:只能被最初给对象存储的页面所访问;

修改localStorage对象、sessionstorage对象都会触发 document 的 storage事件;

localstorage 和 sessionstorage 都是HTML5提供的在客户端存储数据的新方法。

这两个都是windows对象的属性。

其主要区别是:

localStorage - 没有时间限制的数据存储,主要用来存储ajax返回的数据,加快下次访问的渲染速度。

sessionStorage - 针对一个 session 的数据存储。浏览器关闭后就删除。

不同的浏览器无法共享localStorage或sessionStorage中的信息。

注意:cookies、localStorage、sessionStorage的区别

1. 存储时间不同

持久cookies在过期日期之前都会存在;

localStorage会一直存在,除非主动删除;

sessionStorage在标签页关闭之后就会删除;

2. 存储的位置不同

持久cookies是存在用户终端,也就是电脑硬盘上,cookies始终在同源的http请求中携带,会在浏览器和服务器间来回传递。

localStorage和sessionStorage是存在浏览器端;

3. 存储大小不同

cookies数据大小不能超过4k;

sessionStorage和localStorage存储大小比cookies大得多,可以达到5M;

4. cookie还需要指定作用域,不允许跨域调用

localStorage、sessionStorage的使用场景:

localStorage实现离线操作,新闻编辑上传功能,离线时保存在本地,有线时上传;保存用户配置项。

希望用户关闭页面之后就销毁的数据可以保存在sessionStorage中;

(6). application cache 离线存储

1.什么是application cache

application cache是HTML5的新特性,允许浏览器在本地存储页面所需要的资源,使得页面离线也可以访问。

在用户没有与因特网进行连接时,可以正常访问站点或应用,在用户与因特网连接时,更新用户机器上的缓存文件。

application cache是从浏览器的缓存中分出来的一块缓存区。

如何判断设备是否离线?

if(navigator.onLine) {//设备在线时的操作} else {//设备离线时的操作}

window对象上定义了2个事件:

online: 设备从离线变成在线;

offline: 设备从在线变成离线.

    推荐阅读
  • 中考铅球标准动作双手(中考体育项目居家锻炼指南③)

    由于项目特点,推铅球具有一定的危险性。在练习的过程中,要注意安全,不要站立在落地区范围内,同时也要注意观察,防止有人从落地区经过,避免出现伤害事故!推铅球场地简介动作要领两脚站位及身体准备姿势以右手推铅球为例。推球的同时,左腿用力向上蹬直,以增加铅球向前和向上的力量。球出手后,右腿迅速与左脚交换,迅速降低身体重心,缓冲向前的力量,维持身体平衡。

  • 映客怎么赚钱快(映客直播新人起步方法)

    陌陌的三季度财报显示,净利润4950万美元,同比增长1182%。欢聚时代的最新财报也验证了秀场模式吸金的能力。探索商业化之路9月份,昆仑万维的一组公告,让映客的财务数据曝光。公告称,昆仑万维公司拟出售所持有的网络直播平台映客3%的股权,售价为2.1亿元。今年1月4日,昆仑万维向映客投资6800万元,取得18%的股权。2015年,映客总收入为3048.36万元,净利润仅为167.28万元。10月份曝光的映客广告方案,预示着直播平台已经在探索新的盈利方式。

  • 高度近视黄斑病变会癌变吗(宋宗明教授谈近视性黄斑病变的分级与处理)

    但近视性黄斑病变种类较多,治疗不能一概而论。近视性黄斑病变分级近视性黄斑变性常见于高度近视眼,由于后极部向后扩张,导致黄斑区视网膜和脉络膜张力增大,在玻璃体液化、劈裂发生后,容易发生黄斑裂孔,继而发生视网膜脱离。目前可以治疗的近视性眼底病变包括脉络膜新生血管、视网膜脱离、黄斑劈裂和裂孔,萎缩和变性目前不可治疗。

  • 描写树林的美句子(描写树林优美的句子)

    描写树林的美句子夏天来到,小树林的主角应该是枣树了,春天,万木吐翠百花争艳之时,看不见枣花的踪影,等到繁华尽失,深藏不露的枣花就再也沉不住气了,她在枣叶下绽出千朵万朵小小的小骨朵儿,密密麻麻地,远远望去,枣树就象穿上了一件米黄色的锦袍,枣花的颜色是淡淡的浅黄,如果不走近,很难能看清楚真正的枣花,枣花的花骨朵不大,狭小的花瓣浅浅地镶嵌在墨绿的叶子中央,看上去是那么的婀娜、玲珑。

  • 金针菇这么吃最过瘾(金针菇这样炸着吃)

    金针菇中还含有18种氨基酸。金针菇具有较高的营养价值和药用价值,在国际市场上被誉为“超级保健食品”。然后把刀横着把金针菇切成片。取一个长盘子,放入面粉和生粉,面粉和生粉的比例是1:1,这样的配比炸出来的金针菇才又酥又脆。放入金针菇小火慢炸,等其定型以后再翻面。4炸金针菇要炸两遍,第1遍炸至颜色发白,第2遍炸成金黄色,这样炸出来的金针菇,又香又脆,酥的掉渣。

  • 促进消化的食物姜(大补命门冬天常吃这菜)

    1月14日周五冬季宜温补,以免“上火”。命门指的是命门穴,位于后腰,是补肾壮阳的要穴,命门一固诸寒皆散。常吃茴香有助于温补肾阳,消散寒气。茴香菜虽然样貌“平平无奇”,却自带一股特殊的芳香气味,这是因为其含有的茴香油;这种物质能刺激食欲,促进消化液分泌,有助于改善食欲不振、消化不良等问题。小编用它给大家带来一道畅通气血的姜香炝饼丝,还会用到“特殊的姜”,散寒效果更好。这种“特殊的姜”是什么呢?

  • 众泰八字(盲人摸象与庖丁解牛)

    益维大门口众泰汽车品牌改为江南制造,这是众泰与江南分而治之的节奏。一汽就是借着重整众泰,把新能源这块直接战略南下,快速布局全国。包括以后临沂的,只是在生产组织和企业框架内,又与众泰有关,但实际上是浙江政府有关。深商集团代表一汽在联合地方政府与产投谈。盘子大是好事,地方政府参与也是好事。让重庆基地生产老车型,估计重庆政府不会乐意。永康基地生产T300,重庆基地代工某款电动车。重庆基地已经改造将近20天了。

  • 手相怎么看掌纹(手相中断掌纹值得你拥有吗)

    我认为这种说法不可靠,我有一位断掌纹的生意伙伴,他的大方是出了名的。这种说法有点夸张。我看过十几个低能儿的掌纹,居然超过一半是断掌纹。做一件事情从来不不会半途而废,所以能在事业上取得大的成功。断掌纹也是不利婚姻的,跟川字掌有些相似之处。婚姻会因为自己的性格产生影响。他们擅长把握机会,如果掌纹中有事业线或太阳线,一定会在财富和领导力方面获得成就。

  • 冰箱坏了只能冷冻不能保鲜(冰箱坏了不能保鲜只能冷冻怎么做)

    下面内容希望能帮助到你,我们来一起看看吧!冰箱坏了只能冷冻不能保鲜冰箱老化原因导致。时间长了,冰箱门密封条变形,老化,造成密封不严。停了冰箱并融化冰块。看一下保鲜室,里面有一个漏水的圆孔,你先把冰箱停了,等冷冻室的冰完全融化后,找一根细塑料管,插进圆孔内,用嘴或气筒吹一下,吹通气为止。找一些薄海绵,冰箱内放入一个手电筒打开,关上冰箱门,在能看见光亮的地方,把海绵垫入密封条内,调整到看不见光亮为止。