浏览器HTTP缓存机制

介绍HTTP缓存之前先简单说一下Web缓存

Web缓存是一种保存Web资源副本并在下次请求时直接使用该副本的技术。

       Web缓存可以分为这几种:浏览器缓存、CDN缓存、服务器缓存、数据库数据缓存 。因为可能会直接使用副本免于重新发送请求或者仅仅确认资源没变无需重新传输资源实体,Web缓存可以减少延迟加快网页打开速度、重复利用资源减少网络带宽消耗、降低请求次数或者减少传输内容从而减轻服务器压力。

       这篇文章主要讨论和前端密切相关的浏览器HTTP缓存机制。浏览器HTTP缓存可以分为强缓存协商缓存强缓存协商缓存最大也是最根本的区别是:强缓存命中的话不会发请求到服务器(比如chrome中的200 from memory cache),协商缓存一定会发请求到服务器,通过资源的请求首部字段验证资源是否命中协商缓存,如果协商缓存命中,服务器会将这个请求返回,但是不会返回这个资源的实体,而是通知客户端可以从缓存中加载这个资源(304 not modified)。
强缓存与协商缓存

浏览器HTTP缓存由HTTP报文的首部字段决定

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
HTTP 协议中的缓存机制可以分为两种:强缓存和协商缓存。 1. 强缓存缓存是指浏览器在请求资源时,直接从本地缓存中获取资源,而不会发送请求到服务器。强缓存可以通过设置响应头中的 Cache-Control 和 Expires 字段来实现。 - Cache-Control: max-age=3600 表示资源的缓存时间为 3600 秒,即 1 小时。在缓存时间内,浏览器直接从缓存中获取资源,不会向服务器发送请求。 - Expires: Wed, 21 Oct 2021 07:28:00 GMT 表示资源的过期时间为 Wed, 21 Oct 2021 07:28:00 GMT,在过期时间前,浏览器直接从缓存中获取资源,不会向服务器发送请求。 如果同时设置了 Cache-Control 和 Expires 字段,那么 Cache-Control 的优先级更高。 2. 协商缓存 当强缓存失效时,浏览器会发送请求到服务器进行协商缓存。协商缓存可以通过设置响应头中的 ETag 和 Last-Modified 字段来实现。 - ETag ETag 是服务器生成的资源唯一标识符,当资源发生变化时,ETag 值也会发生变化。如果浏览器发送的请求头中包含 If-None-Match 字段,那么服务器会将该字段的值与资源的 ETag 值进行比较,如果相同,则返回 304 Not Modified 状态码,表示资源未发生变化,浏览器可以从缓存中获取资源。 - Last-Modified Last-Modified 是资源最后修改的时间,当资源发生变化时,Last-Modified 值也会发生变化。如果浏览器发送的请求头中包含 If-Modified-Since 字段,那么服务器会将该字段的值与资源的 Last-Modified 值进行比较,如果相同,则返回 304 Not Modified 状态码,表示资源未发生变化,浏览器可以从缓存中获取资源。 如果同时设置了 ETag 和 Last-Modified 字段,那么 ETag 的优先级更高。 需要注意的是,协商缓存虽然可以减少网络请求,但是会增加服务器的负担。因此,对于一些静态资源,可以使用 CDN 加速和缓存来降低服务器的负担。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值