可信网站认证不在有用吗,龙游县住房和城乡建设局网站,北京网站设计制作网站,网站建设 设计那种连接线厂家一、浏览器缓存中常见HTTP头部简介
1、Cache-Control响应头
public#xff1a;表明响应可以被任何对象#xff08;包括#xff1a;发送请求的客户端#xff0c;代理服务器#xff0c;等等#xff09;缓存#xff0c;即使是通常不可缓存的内容。#xff08;例如#…一、浏览器缓存中常见HTTP头部简介
1、Cache-Control响应头
public表明响应可以被任何对象包括发送请求的客户端代理服务器等等缓存即使是通常不可缓存的内容。例如1.该响应没有max-age指令或Expires消息头2. 该响应对应的请求方法是 POST 。
private表明响应只能被单个用户缓存不能作为共享缓存即代理服务器不能缓存它。私有缓存可以缓存响应内容比如对应用户的本地浏览器。
no-cache协商缓存在发布缓存副本之前强制要求缓存把请求提交给原始服务器进行验证。
no-store不使用任何缓存缓存不应存储有关客户端请求或服务器响应的任何内容。
max-ageseconds强制缓存设置缓存存储的最大周期超过这个时间缓存被认为过期 (单位秒)。与Expires相反时间是相对于请求的时间。
s-maxageseconds强制缓存覆盖max-age或者Expires头但是仅适用于共享缓存 (比如各个代理)私有缓存会忽略它。
2、Expect响应头
Expires: http-date响应头包含日期/时间即在此时候之后响应过期。如果在Cache-Control响应头设置了 max-age 或者 s-max-age 指令那么 Expires 头会被忽略。
3、ETag响应头
HTTP 响应头是资源的特定版本的标识符。这可以让缓存更高效并节省带宽因为如果内容没有改变Web 服务器不需要发送完整的响应。而如果内容发生了变化使用 ETag 有助于防止资源的同时更新相互覆盖“空中碰撞”。
4、Last-Modified响应头
是一个响应首部其中包含源头服务器认定的资源做出修改的日期及时间。它通常被用作一个验证器来判断接收到的或者存储的资源是否彼此一致。由于精确度比 ETag 要低所以这是一个备用机制。包含有 If-Modified-Since 或 If-Unmodified-Since 首部的条件请求会使用这个字段。
5、If-Modified-Since 请求头
If-Modified-Since 是一个条件式请求首部服务器只在所请求的资源在给定的日期时间之后对内容进行过修改的情况下才会将资源返回状态码为 200 。如果请求的资源从那时起未经修改那么返回一个不带有消息主体的 304 响应而在 Last-Modified 首部中会带有上次修改时间。不同于 If-Unmodified-Since, If-Modified-Since 只可以用在 GET 或 HEAD 请求中。
6、If-Unmodified-Since请求头
If-Unmodified-Since 是一个条件式请求首部,只有当资源在指定的时间之后没有进行过修改的情况下服务器才会返回请求的资源或是接受 POST 或其他 non-safe 方法的请求。如果所请求的资源在指定的时间之后发生了修改那么会返回 412 (Precondition Failed) 错误。
7、If-None-Match请求头
If-None-Match 是一个条件式请求首部。对于 GET 和 HEAD 请求方法来说当且仅当服务器上没有任何资源的 ETag 属性值与这个首部中列出的相匹配的时候服务器端才会返回所请求的资源响应码为 200 。如存在服务器端返回响应码 304Not Modified未改变。
二、常见的缓存方式
1、强缓存 根据 Cache-Controlmax-ageseconds或 Expires: http-date判断为强制缓存。 例如Cache-Control 为 max-age 3000意思是说在 3000 秒后该资源过期。
2、协商缓存 根据Cache-Control 值: no-cache 或 max-age0 判断为协商缓存。 浏览器会携带缓存标识 If-None-Match、if-modified-since 向服务器发送请求服务器根据缓存标识来决定该资源是否过期。先判断Etag如有 If-None-Match 继续判断 Last-Modified如有 if-modified-since 如果都相等304否则返回服务器资源和200。 例如Cache-Control : no-cache 意思是使用的协商混存。
3、启发式缓存 当不设置Cache-Control或 Expires时触发启发式缓存。如Date创建时间大于Last-Modified一年那么浏览器会默认进行读取本地缓存时间为1year * 0.1约为36.5天即在接下来的36.5天里不会发送HTTP请求直接拉取本地缓存表现为disk cache或者memory cach。
三、缓存完整流程
1、用户通过浏览器发起请求 。
2、根据 Cache-Control或 Expires字段判断内存中是否存在有效期的强缓存或者启发式缓存如存在内存中返回资源不存在继续判断。
3、根据 Cache-Control或 Expires字段判断磁盘中是否存在有效期的强缓存或者启发式缓存如存在磁盘中返回资源不存在继续判断。
4、根据 Cache-Control或 Expires字段判断是都是协商缓存如是按照协商缓存处理。
5、如Cache-Control no-store 则不进行缓存直接从服务器拉取资源。 四、其他
浏览器和CDN缓存相互独立CND节点收到协商缓存验证时直接通过cnd节点中的资源进行验证。未证实
Cache-Control等字段经过多个nginx时如都设置了Cache-Control值将全部体现在返回包中不会替换。