浏览器强缓存和弱缓存的主要区别

浏览器强缓存与弱缓存

浏览器的缓存机制主要分为两种:强缓存与协商缓存(也称弱缓存)。

强缓存

强缓存是指浏览器在请求一个资源时,不与服务器发生通信,直接从本地缓存中获取资源。如果存在有效的强缓存,浏览器将完全跳过网络请求阶段,显著提升性能和加载速度。

实现方式

强缓存基于HTTP响应头中的特定字段来实现,主要包括:

  1. Cache-Control

    • 这是一种相对新鲜度策略,通过设置max-age指令来表明资源的有效期(单位为秒)。在此期间,浏览器无需向服务器验证资源是否已更新。
  2. Expires

    • 这是一种绝对时间戳策略,用于指定资源的过期时间。若当前时间未超过该时间点,浏览器将使用缓存。

弱缓存/协商缓存

当强缓存失效或不存在时,浏览器会发起网络请求,并携带缓存相关标识到服务器进行验证,询问服务器缓存的资源是否仍有效。这一过程称为协商缓存或弱缓存。

协商机制

协商缓存主要依赖以下HTTP头部信息:

  1. Last-Modified / If-Modified-Since

    • 服务器在返回资源时附带Last-Modified字段,表示资源最后修改的时间。下一次请求时,浏览器发送If-Modified-Since请求头,服务器根据这个时间判断资源是否有更新。若无更新,则返回304状态码及新的响应头(不含资源内容),浏览器继续使用本地缓存的资源。
  2. ETag / If-None-Match

    • 服务器返回资源时可能生成一个唯一标识符ETag。客户端再次请求时携带If-None-Match请求头,服务器依据ETag判断资源是否被修改。若无修改,同样返回304状态码及新的响应头,浏览器继续使用本地缓存。

总结而言,强缓存无需与服务器通信即可决定是否使用缓存,而弱缓存则需要通过与服务器的交互来确认缓存是否仍然有效。。

相关推荐
斯文~1 小时前
「玩透ESA」站点配置阿里云ESA全站加速+自定义规则缓存
阿里云·缓存·云计算·cdn·esa
S***t7141 小时前
Python装饰器实现缓存
缓存
天硕国产存储技术站2 小时前
3000次零失误验证,天硕工业级SSD筑牢国产SSD安全存储方案
缓存·固态硬盘·国产ssd
前端炒粉5 小时前
35.LRU 缓存
开发语言·javascript·数据结构·算法·缓存·js
努力发光的程序员12 小时前
互联网大厂Java面试:从Spring Boot到微服务架构
spring boot·缓存·微服务·消息队列·rabbitmq·spring security·安全框架
zero13_小葵司13 小时前
JavaScript性能优化系列(八)弱网环境体验优化 - 8.3 数据预加载与缓存:提前缓存关键数据
javascript·缓存·性能优化
CS_浮鱼15 小时前
【Linux进阶】mmap实战:文件映射、进程通信与LRU缓存
linux·运维·c++·缓存
q***318318 小时前
Window下Redis的安装和部署详细图文教程(Redis的安装和可视化工具的使用)
数据库·redis·缓存
梁bk20 小时前
Redis 多级缓存架构学习笔记
redis·缓存·架构
q***81641 天前
【Redis】centos7 systemctl 启动 Redis 失败
数据库·redis·缓存