http协议中的缓存:强缓存、协商缓存

此篇抽自本人之前的文章:http面试题整理 。 别急着跳转,先把缓存知识学会了~

http中的缓存分为两种:强缓存、协商缓存。

  1. 强缓存 响应头中的 status 是 200,相关字段有expires(http1.0),cache-control(http1.1),两者同时出现时 cache-control 优先级更高。主要是利用 cache-controlmax-age值来进行判断。

    浏览器再次请求服务器时,浏览器会先判断max-age,如果到期则直接请求服务器,否则直接从缓存中读取。

    响应头的字段如图所示:

  2. 协商缓存 响应头中的 status 是 304,相关字段有 Etag / If-No-MatchLast-Modified / If-Modified-Since。 (1) 服务器的 ETag 和 浏览器的 If-None-Match 对应

    Etag(服务器): 上次加载时,服务器的 response header 返回的; If-No-Match(浏览器): 浏览器请求时的 request header 里的,取的是 Etag 的值。

    如果服务器为请求的资源确定的 ETag 标头的值与浏览器请求中的 If-None-Match 值相同,则服务器将返回 304 Not Modified。表示资源文件没有发生改变,命中协商缓存。

    服务器优先考虑Etag。

    Etag 与 Last-Modifed 均是服务器的响应头返回的,如图所示:

    (2) 服务器的 Last-Modified 和 浏览器请求的 If-Modified-Since 对应

    Last-Modified(服务器):该资源文件最后一次更改时间,服务器的 response header 里返回; If-Modified-Since(浏览器):浏览器请求时的 request header 里的,取的是 Last-Modify 的值。

在下一次发送请求时,服务器在接收到会做比对,如果相同,则命中协商缓存。 If-No-Match 与 If-Modified-Since 是浏览器发送的,请求头可以简略为以下格式:

sql 复制代码
GET / HTTP/1.1
Host: example.com
Cache-Control: max-age=0
If-None-Match: "deadbeef"  // 对应服务端的标记Etag
If-Modified-Since: Tue, 22 Feb 2022 20:20:20 GMT // 对应服务端的Last-Modified

补充知识,常见的状态码:

以2开头的代表的成功的返回,以3开头代表重定向,以4开头是客户端、用户操作的问题,以5开头是服务器端的错误。

状态码 含义
200 请求成功。
301 永久重定向,请求的网页已永久移动到新位置,浏览器会自动重定向到新的 url 地址。
302 临时重定向,服务器目前从不同位置的网页响应请求,可使用原有 url 地址。
303 查看其它位置,重定向。
304 Not Modified,资源未作修改。协商缓存。
305 所访问资源必须通过代理访问。
401 要求用户要进行身份验证,未登录等情形。
403 请求已发出,但服务端禁止访问。
404 页面无法找到。
500 服务器内部错误。
501 服务器不支持请求的功能。
502 网关错误。
相关推荐
namekong84 小时前
清理谷歌浏览器垃圾文件 Chrome “User Data”
前端·chrome
开发者小天4 小时前
调整为 dart-sass 支持的语法,将深度选择器/deep/调整为::v-deep
开发语言·前端·javascript·vue.js·uni-app·sass·1024程序员节
天***88966 小时前
HTTP 协议的常用方法有哪些?(GET、POST、PUT、DELETE、PATCH)各自的作用和区别是什么?
网络·网络协议·http
李少兄7 小时前
HTML 表单控件
前端·microsoft·html
学习笔记1018 小时前
第十五章认识Ajax(六)
前端·javascript·ajax
消失的旧时光-19438 小时前
Flutter 异步编程:Future 与 Stream 深度解析
android·前端·flutter
曹牧9 小时前
C# 中的 DateTime.Now.ToString() 方法支持多种预定义的格式字符
前端·c#
勿在浮沙筑高台9 小时前
海龟交易系统R
前端·人工智能·r语言
歪歪1009 小时前
C#如何在数据可视化工具中进行数据筛选?
开发语言·前端·信息可视化·前端框架·c#·visual studio
Captaincc10 小时前
AI 能帮你写代码,但把代码变成软件,还是得靠人
前端·后端·程序员