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

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

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

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: 设备从在线变成离线.

    推荐阅读
  • 口袋妖怪漆黑的魅影急冻鸟在哪(急冻鸟怎么抓)

    口袋妖怪漆黑的魅影里的三圣鸟之一,能够将一切冻结,从关东地区开始就出现在神秘的岛屿,那么急冻鸟要怎么获得呢?,今天小编就来聊一聊关于口袋妖怪漆黑的魅影急冻鸟在哪?首先来到冬雪镇。然后向左走,走到一个瀑布面前,先用冲浪术进入水中。进入到山洞里面,看到地面上全是冰,可以直接一步滑到急冻鸟面前了,点击A键进入战斗即可捕捉。

  • 李宗翰大师个人资料(从民国第一小生沦为渣男配角专业户)

    今年年初,由孙俪、罗晋主演的《安家》掀起了收视狂潮。可以说,《梧桐雨》成就了李宗翰。但这一次,不再是人见人爱的民国小生,而是人人喊打的渣男专业户。但没想到的是,为人着想的李宗翰却反而给自己招来了麻烦。李宗翰知道后就把酒店告上了法庭,他要他们知道,做人要有良知,要有最基本的职业道德。曾经在采访中,李宗翰被问到如何面对中年危机。其实,如果岁月可回头,李宗翰或许就不会成为演员。

  • 平安夜快乐英文怎么说(Merry(Christmas(Eve)

    以下内容希望对你有帮助!平安夜快乐英文怎么说中文:平安夜快乐。HolyNig、ChristmasEve、SilentNight圣诞节是基督教徒纪念耶稣基督诞生的日子,圣诞节指圣诞日“ChristmasDay”或圣诞节节期“Christmastide”,即12月24日至第二年1月6日这段时间。对西洋国家来说“平安夜”就是指圣诞节前夕,也可说ChristmasEve,但就宗教群体也常称“平安夜”为“SilentNight”。

  • 种向日葵的方法和诀窍(向日葵种植技术)

    种向日葵的方法和诀窍选种:观赏类向日葵的话,要选择小棵类的向日葵种子,注意挑选成熟的比较饱满的瓜子。种进去后再覆一层薄土,用喷壶喷水,让土壤保持湿润的状态,然后将其放在室内有阳光的地方养护。若是养在室外则要及时补水,不能让土壤发干。并施加一些堆肥,增加土壤中的养分。盆土准备好后就可以将向日葵的小苗种到花盆中。

  • 孙武为什么从齐国到吴国(孙武到吴国的原因)

    齐景公初年,左相庆封灭掉了右相崔杼。后来,内乱日甚一日,齐国公室同四大家族的矛盾,四大家族相互之间争权夺利的斗争,愈演愈烈。中国春秋时期著名的军事家、政治家,尊称兵圣或孙子(孙武子),又称“兵家至圣”,被誉为“百世兵家之师”、“东方兵学的鼻祖”。他在柏举之战率领吴国军队大败楚国军队,占领楚国都城郢城,几近覆亡楚国。

  • 牙周袋变深怎么办(口腔中的盲袋)

    大部分人的智齿是不能完全萌出的,这样的话,智齿在牙床下,就会被牙床组织给包裹住,这便形成了盲袋。因为有智齿和牙床为盲袋形成的“天然屏障”,盲袋便可以顺利逃过牙刷、漱口水的清洗冲击,不间断的保持工作。在临床上,拔掉智齿一段时间后,盲袋继续存在且持续性发炎的病例也不在少数。如果牙医能很好的处理拔掉智齿后牙床组织的缝合,那么盲袋便不会再有生存的空间。

  • 国外iphone到国内无法连接wifi(国外iphone到无法连接wifi怎么办)

    下面更多详细答案一起来看看吧!国外iphone到国内无法连接wifi网络制式不兼容就会出现这情况,最好到当地营业厅咨询相关人员,找出可以接受的解决方案。另外,就算网络制式兼容不了,WIFI一般大多数都可以上的,如果路由器是自己的,关闭路由器的WIFI加密模式,看一下这样连行不行,如果不行,很有可能是手机坏了。

  • 米包子的做法(米包子怎么做)

    材料:糯米饭1小碗、鸡蛋1个、火腿2根、榨菜30克,接下来我们就来聊聊关于米包子的做法?以下内容大家不妨参考一二希望能帮到您!

  • 狗肚子里虫多的症状(肚子里有虫子的狗)

    宠主最好及时给狗狗驱虫,不然对狗狗的身体伤害是很大的。宠主翻开狗狗的毛发,还会看到红点、黑色的颗粒。如果你家狗狗牙龈和眼睑过度发白的话,那可能是因为感染寄生虫而导致的贫血症状了,这种情况是比较严重的,宠主最好及时带狗狗到医院检查,并且要及时驱虫。

  • 想你却又不知道打扰你(却不敢轻易打扰你)

    最近朋友圈中有对情侣正在闹分手,作为双方的共同好友,我是纳闷的。01▼两人在一起时,就是需要通过相互亏欠、彼此麻烦来维系这段关系。如果想要崭新的关系,如果想拥有爱情,就必须越界。人和人之间的交往,就是在爱与被爱,需要与被需要中,找到自己的存在感和安全感。在爱的人面前,可以不用那么坚强,可以卸下所有的防备和顾虑,做那个最真实最柔软的自己。保持独立,并不意味着完全不用依赖别人。