http缓存?强制缓存和协商缓存?

HTTP缓存是一种优化网络资源加载速度的技术,通过减少从服务器获取相同资源的次数来实现。HTTP缓存机制包括强制缓存和协商缓存(对比缓存)两种类型。

强制缓存

强制缓存是指浏览器在接收到服务器返回的响应后,会将响应内容和相关缓存信息(如Expires和Cache-Control)保存在本地。当浏览器再次请求该资源时,会先检查缓存中的信息,如果缓存中的信息表明资源未过期,则直接从缓存中加载资源,不会向服务器发送请求。
强制缓存有两种实现方式:

  1. Expires:在HTTP响应头中设置一个过期时间,浏览器在过期时间之前不会向服务器发送请求,而是直接使用缓存中的资源。但是,由于Expires是基于服务器时间来计算的,如果服务器时间被修改,可能会导致缓存失效。
  2. Cache-Control:这是一个更灵活的机制,通过设置max-age属性来指定资源在缓存中的存活时间。浏览器在接收到响应后,会根据max-age的值来判断资源是否过期。与Expires相比,Cache-Control是基于客户端时间来计算的,因此更可靠。
协商缓存

当强制缓存失效时,浏览器会尝试使用协商缓存。协商缓存是指浏览器在缓存失效后,会向服务器发送一个请求,并携带缓存中资源的标识(如Last-Modified或ETag)。服务器收到请求后,会检查该资源是否有变化,如果资源没有变化,则返回304状态码和空的响应体,浏览器可以直接从缓存中加载资源;如果资源有变化,则返回新的资源内容。
协商缓存有两种实现方式:

  1. Last-Modified/If-Modified-Since:服务器在响应头中返回资源的最后修改时间(Last-Modified),浏览器在下次请求时会在请求头中携带上次获取资源的时间(If-Modified-Since)。服务器比较这两个时间,如果资源没有变化,则返回304状态码;否则,返回新的资源内容。
  2. ETag/If-None-Match:服务器为资源生成一个唯一的标识(ETag),并在响应头中返回给浏览器。浏览器在下次请求时会在请求头中携带该标识(If-None-Match)。服务器检查该标识是否与当前资源的标识一致,如果一致,则返回304状态码;否则,返回新的资源内容。ETag相对于Last-Modified更可靠,因为ETag考虑了资源内容的变化,而不仅仅是修改时间。

总的来说,强制缓存和协商缓存是HTTP缓存机制的两个重要组成部分,它们共同协作以提高网页加载速度和用户体验。

相关推荐

  1. http缓存强制缓存协商缓存

    2024-02-22 07:54:03       27 阅读
  2. HTTP强制缓存协商缓存

    2024-02-22 07:54:03       15 阅读
  3. http协商缓存缓存

    2024-02-22 07:54:03       11 阅读
  4. Http协议Http缓存

    2024-02-22 07:54:03       7 阅读
  5. 什么是强缓存协商缓存

    2024-02-22 07:54:03       34 阅读
  6. 浏览器强缓存协商缓存

    2024-02-22 07:54:03       36 阅读
  7. 缓存协商缓存的区别?

    2024-02-22 07:54:03       20 阅读

最近更新

  1. TCP协议是安全的吗?

    2024-02-22 07:54:03       16 阅读
  2. 阿里云服务器执行yum,一直下载docker-ce-stable失败

    2024-02-22 07:54:03       16 阅读
  3. 【Python教程】压缩PDF文件大小

    2024-02-22 07:54:03       15 阅读
  4. 通过文章id递归查询所有评论(xml)

    2024-02-22 07:54:03       18 阅读

热门阅读

  1. 利用System.Web.HttpRuntime.Cache制作缓存工具类

    2024-02-22 07:54:03       30 阅读
  2. 神经网络量化

    2024-02-22 07:54:03       28 阅读
  3. C语言K&R圣经笔记 8.1文件描述符 8.2低级IO

    2024-02-22 07:54:03       26 阅读
  4. Gson 库的使用

    2024-02-22 07:54:03       24 阅读
  5. Linux常见命令 | 文件传输命令scp

    2024-02-22 07:54:03       25 阅读
  6. [opencvsharp]将Mat转float数组

    2024-02-22 07:54:03       29 阅读
  7. CSS总结

    CSS总结

    2024-02-22 07:54:03      27 阅读
  8. scss导出颜色变量为空对象

    2024-02-22 07:54:03       28 阅读
  9. 事件流 事件委托

    2024-02-22 07:54:03       33 阅读
  10. Vue中v-model的原理

    2024-02-22 07:54:03       26 阅读
  11. docker入门介绍

    2024-02-22 07:54:03       32 阅读