【计算机网络】强缓存和协商缓存

强缓存和协商缓存是浏览器缓存机制的两种不同策略,用于优化网页加载速度和减少网络请求。

强缓存(HTTP Cache-Control 和 Expires)

强缓存是通过在HTTP响应头中设置相关字段来实现的,它告诉浏览器在一段时间内直接使用缓存的资源,而不必再向服务器发起请求。两个主要的HTTP响应头字段用于强缓存:

  1. Cache-Control :这是一个指令,可以设置多种缓存策略,如public(允许所有缓存)、private(只允许私有缓存,如浏览器缓存,不允许代理服务器缓存)、max-age(指定缓存的最长时间,以秒为单位)等。

  2. Expires:这是一个日期时间,指定了资源的到期时间。在到期时间之前,浏览器可以从缓存中加载资源,无需再次请求。

协商缓存(HTTP ETag 和 Last-Modified)

协商缓存是通过在HTTP请求头中包含条件信息,与服务器进行"协商",以确定是否需要重新获取资源。这个机制避免了不必要的网络传输,当资源没有发生实际变化时,浏览器可以直接使用缓存。

  1. ETag (实体标签):这是服务器生成的资源唯一标识符,可以是资源内容的哈希值或其他标识。当浏览器请求资源时,服务器会在响应头中发送ETag。如果浏览器再次请求资源,它会在请求头中携带If-None-Match字段,包含上次获取的ETag。服务器会检查ETag是否与当前资源匹配,如果匹配则返回304 Not Modified,浏览器可以使用缓存。

  2. Last-Modified :这是资源的最后修改时间,服务器在响应头中发送。浏览器再次请求资源时,会在请求头中携带If-Modified-Since字段,包含上次获取的资源的最后修改时间。服务器会检查最后修改时间是否一致,如果一致则返回304 Not Modified,浏览器可以使用缓存。

强缓存和协商缓存可以结合使用,从而更有效地控制资源的缓存策略。当浏览器首次请求资源时,会根据响应头中的缓存策略来决定是否将资源存入缓存。当浏览器再次请求资源时,会根据缓存策略和协商缓存机制来决定是否使用缓存,或者是否与服务器进行协商,以确定是否需要重新获取资源。

相关推荐
小丁爱养花21 分钟前
Redis - set & zset (常用命令/内部编码/应用场景)
数据库·redis·缓存
小李独爱秋1 小时前
计算机网络经典问题透视:当路由器需要同时连接以太网和ATM网络时,需要添加什么硬件?
运维·网络协议·计算机网络·网络安全·智能路由器
大G的笔记本2 小时前
用 Redis 的 List 存储库存队列,并通过 LPOP 原子性出队来保证并发安全案例
java·数据库·redis·缓存
元亓亓亓4 小时前
考研408--计算机网络--day2--性能指标&分层结构&OSI&TCP/IP
计算机网络·考研
报错小能手5 小时前
计算机网络自顶向下方法21——运输层 详解无连接运输:UDP (报文段结构、检验和)
网络协议·计算机网络·udp
、BeYourself5 小时前
【随机访问介质访问控制-1】为什么纯 ALOHA 效率不到 20%?3 大随机访问 MAC 协议拆解
网络·计算机网络·数据链路层
_殊途8 小时前
计算机网络-网络层
网络·计算机网络·智能路由器
七七七七078 小时前
【计算机网络】深入理解网络层:IP地址划分、CIDR与路由机制详解
linux·服务器·计算机网络·智能路由器
IDOlaoluo15 小时前
TinyRDM 1.2.3 Windows版安装教程(附Redis客户端下载及详细步骤)
数据库·redis·缓存
2501_9387699917 小时前
React Server Components 进阶:数据预取与缓存
前端·react.js·缓存