强缓存和协商缓存的区别

news2024/10/6 6:02:03

强缓存和协商缓存是Web开发中用于优化页面加载性能的两种主要缓存机制,它们之间存在显著的区别。以下是对这两种缓存机制的详细比较:

一、定义与工作原理

  1. 强缓存

    • 定义:强缓存是指在浏览器发送请求前,先检查本地缓存中是否存在可用的资源副本。如果存在且未过期,则直接使用本地缓存,不向服务器发送请求。
    • 工作原理:当客户端首次请求资源时,服务器会在响应头中包含缓存控制信息,如Cache-Control(使用max-age指定资源的最大缓存时间)或Expires(指定资源的过期时间,是一个GMT格式的日期字符串)。客户端在后续请求时,会根据这些缓存控制信息判断是否使用本地缓存。
  2. 协商缓存

    • 定义:协商缓存是指在浏览器发送请求后,服务器会先验证该资源是否被修改过。如果未被修改,则返回一个特定的响应头,告诉浏览器可以使用本地缓存。
    • 工作原理:当客户端再次请求资源时,会在请求头中包含一些验证信息,如If-Modified-Since(携带上一次请求时服务器返回的资源最后修改时间)或If-None-Match(携带上一次请求时服务器返回的资源的唯一标识符ETag)。服务器会根据这些信息判断资源是否发生了变化,并返回相应的响应。如果资源未发生变化,则服务器返回304状态码,表示客户端可以继续使用本地缓存的数据。

二、缓存命中与失效

  1. 强缓存

    • 缓存命中:在缓存有效期内,浏览器会直接读取本地缓存,不会向服务器发送请求。此时,响应状态码为200(OK)。
    • 缓存失效:缓存过期后,或浏览器强制刷新(如F5刷新或Ctrl+F5强制刷新)时,强缓存不会生效,浏览器会重新向服务器发送请求。
  2. 协商缓存

    • 缓存命中:如果资源未发生变化,服务器会返回304状态码,表示客户端可以继续使用本地缓存的数据。
    • 缓存失效:如果资源有更新,服务器会返回新的资源数据,并可能更新相关的缓存标识(如ETag或Last-Modified)。此外,即使缓存未过期,但在某些情况下(如浏览器缓存策略设置、用户行为等),协商缓存也可能失效,导致浏览器重新向服务器发送请求。

三、应用场景与优势

  1. 强缓存

    • 应用场景:适用于那些不经常变化的资源,如图片、CSS、JavaScript文件等。
    • 优势:可以大大减少网络传输,提高页面加载速度和服务性能。因为一旦资源被缓存,后续请求就可以直接从本地缓存中读取,而无需向服务器发送请求。
  2. 协商缓存

    • 应用场景:适用于那些可能会发生变化的资源,如动态生成的页面、用户数据等。
    • 优势:可以减少不必要的数据传输,提高服务器性能。因为当资源未发生变化时,服务器只需返回304状态码,而无需传输整个资源数据。同时,协商缓存还可以确保客户端始终使用最新的资源数据。

四、实现方式

  1. 强缓存

    • 主要基于ExpiresCache-Control这两个HTTP头信息来实现。通过设置这些头信息的值,可以指定缓存的有效期。
  2. 协商缓存

    • 主要基于ETagLast-Modified这两个HTTP头信息来实现。ETag是一个资源的唯一标识符,通常是根据资源内容生成的哈希值;Last-Modified表示资源最后修改的时间。

综上所述,强缓存和协商缓存各有其特点和适用场景。在实际应用中,通常会结合使用这两种缓存策略,以实现更好的性能和用户体验。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2191266.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

文心智能体——制作你的专属AI

随着社会的进步和互联网技术的发展,人工智能领域正蓬勃发展。最近几年关于人工智能的新闻日渐增多并且成为了当代最大的热点,所有的领域都在引进AI、训练AI、使用AI,AI正逐步融入人们的生活。从前几年chatGPT大语言模型的横空出世&#xff0c…

【CSDN入门级教程】

这里写自定义目录标题 欢迎使用Markdown编辑器新的改变功能快捷键合理的创建标题,有助于目录的生成如何改变文本的样式插入链接与图片如何插入一段漂亮的代码片生成一个适合你的列表创建一个表格设定内容居中、居左、居右SmartyPants 创建一个自定义列表如何创建一个…

Linux进程调度和进程切换

并行(Parallel) 含义:并行是指多个任务在同一时刻同时执行。 硬件要求:需要多个处理器(如多核CPU)或者多台计算设备来实现,这些执行单元能够真正地同时处理不同的任务。例如,一个具…

vite学习教程05、vite+vue2构建本地 SVG 图标

文章目录 前言一、构建本地SVG图标详细步骤1、安装开发依赖2、配置vite2.1、配置vite.config.js2.2、封装vite引入插件脚本 解决报错:can not find package fast-glob imported 二、实际应用应用1:未封装,直接vue应用应用2:封装vu…

Self-Operating Computer:基于PyAutoGui加AI实现无人“驾驶“电脑,让Python带你走近未来世界

近年来,AI 领域不断取得突破,特别是多模态模型的出现,为计算机无人操控带来了全新的可能性。 想象一下,你的电脑不再需要你手动操作,而是可以像人一样,理解你的指令,并自动执行一系列鼠标键盘操…

【word脚注】双栏设置word脚注,脚注仅位于左栏,右栏不留白

【word脚注】双栏设置word脚注,脚注仅位于左栏,右栏不留白 调整前效果解决方法调整后效果参考文献 调整前效果 调整前:脚注位于左下角,但右栏与左栏内容对其,未填充右下角的空白区域 解决方法 备份源文件复制脚注内…

MySQL--聚合查询、联合查询、子查询、合并查询(上万字超详解!!!)

目录 一、前言二、聚合查询2.1 聚合函数2.1.1 COUNT():统计所有行2.1.2 SUM(列名) 求和2.1.3 AVG()2.1.4 MAX()、MIN() 2.2 GROUP BY子句(分组查询)2.3 HAVING 三、联合查询3.1表的笛卡儿积3.2内连接3.2.1 例题一3.2.2 例题二 3.3外连接3.3.1 右外连接3.…

【每天学个新注解】Day 16 Lombok注解简解(十五)—@FieldNameConstants

FieldNameConstants 根据属性名生成常量类的常量。 1、如何使用 加在需要根据属性名生成常量的属性上。 2、代码示例 例: FieldNameConstants public class Test {private String iAmAField;private int andSoAmI;FieldNameConstants.Exclude private int asA…

Microsoft AI部门的CEO额备忘录

每周跟踪AI热点新闻动向和震撼发展 想要探索生成式人工智能的前沿进展吗?订阅我们的简报,深入解析最新的技术突破、实际应用案例和未来的趋势。与全球数同行一同,从行业内部的深度分析和实用指南中受益。不要错过这个机会,成为AI领…

kafka-windows集群部署

kafka-windows集群部署目录 文章目录 kafka-windows集群部署目录前言一、复制出来四个kafka文件夹二、修改集群每个kafka的配置文件四、启动zookeeper,kafka集群 前言 部署本文步骤可以先阅读这一篇博客,这篇是关于单机kafka部署测试的。本文用到的文件…

VUE2常见问题以及解决方案汇总(不断更新中)

解决vue项目中 el-table 的 row-click 事件与行内点击事件冲突,点击事件不生效(表格行点击事件和行内元素点击事件冲突)需要阻止事件冒泡 问题描述 1.点击列的编辑按钮,会触发按钮本身事件,同时会触发行点击事件 2.点…

自用Proteus(8.15)常用元器件图示和功能介绍(持续更新...)

文章目录 一、 前言二、新建工程(以51单片机流水灯为例)2.1 打开软件2.2 建立新工程2.3 创建原理图2.4 不创建PCB布版设计2.5 创建成功2.6 添加元器件2.7 原理图放置完成2.8 编写程序,进行仿真2.9 仿真 三、常用元器件图示和功能介绍3.1 元件…

春秋云镜靶场之CVE-2022-28525

1.环境搭建 我们开启环境 可以看到题目提示我们是文件上传漏洞,那么我们就进行测试 2.开启环境 我们开启环境,可以看到是一个登录页面,登录页面:一种是弱口令,一种是自己进行注册,一种是SQL注入,一种是在…

【rCore OS 开源操作系统】Rust 异常处理

【rCore OS 开源操作系统】Rust 异常处理 前言 虽然人还在旅游ing,但是学习不能停止,所以还是写点博客记录下。 对于 Rust 的异常处理,我的感受是:晦涩难懂,繁琐难记。 但是没办法,正如一位故人所说的&…

算法 | 位运算(哈希思想)

位运算 &与两个位都为1时&#xff0c;结果才为1&#xff08;有0为0&#xff09;|或两个位都为0时&#xff0c;结果才为0&#xff08;有1为1&#xff09;^异或两个位相同为0&#xff0c;相异为1~取反0变1&#xff0c;1变0<<左移各二进位全部左移若干位&#xff0c;高…

【FPGA开发】Modelsim如何给信号分组

前面已经发布过了一篇关于 Modelsim 的入门使用教程&#xff0c;针对的基本是只有一个源文件加一个仿真tb文件的情况&#xff0c;而实际的工程应用中&#xff0c;往往是顶层加多个底层的源文件结构&#xff0c;如果不对信号进行一定的分组&#xff0c;就会显得杂乱不堪&#xf…

LSM6DSV16X基于MLC智能笔动作识别(4)----中断获取智能笔状态

LSM6DSV16X基于MLC智能笔动作识别.4--中断获取智能笔状态 概述视频教学样品申请源码下载硬件准备开启INT中断参考驱动程序配置中断主程序演示 概述 LSM6DSV16X 支持通过中断&#xff08;INT&#xff09;输出 MLC&#xff08;机器学习核&#xff09;识别的动作。具体来说&#…

YOLOv8改进线性注意力模块 ICCV2023 FLatten Transformer

1,原理部分 论文地址:2308.00442 (arxiv.org) 在将 Transformer 模型应用于视觉任务时,自我注意的二次计算复杂性一直是一个持续的挑战。另一方面,线性注意力通过精心设计的映射函数近似 Softmax 操作,通过其线性复杂性提供了一种更有效的替代方案。然而,当前的线性注意…

手机sd卡数据被清空怎么恢复原状?高效、可行的恢复策略

在数字化时代&#xff0c;手机SD卡作为我们存储重要数据的“数字仓库”&#xff0c;其安全性与稳定性直接关系到我们日常生活的便捷与信息安全。然而&#xff0c;不慎操作或系统故障导致的SD卡数据清空&#xff0c;常常让人措手不及&#xff0c;焦虑万分。面对这一挑战&#xf…

@antv/x6 导出图片下载,或者导出图片为base64由后端去处理。

1、导出为文件的格式&#xff0c;比如 PNG graph.exportPNG(function (dataURL) {console.log(dataURL);let img document.getElementById(img) as HTMLImageElement;img.src dataURL;},{backgroundColor: #fff,padding: [20, 20, 20, 20],quality: 1,width: graph.options.w…