网络基础:HTTP(6):HTTP的缓存过程

一、HTTP的缓存过程是怎么样的?
通常的情况下的步骤是:

1.客户端向服务器发出请求,请求资源。

2.服务器返回资源,并通过响应头决定缓存策略。

3.客户端根据响应头的策略决定是否缓存资源(这里假设是),并将响应头与资源缓存下来。

4.在客户端再次请求并命中资源的时候,此时客户端去检查上次缓存的缓存策略,根据策略的不同,是否过期等判断是直接读取本地缓存还是与服务器协商缓存。
在这里插入图片描述
二、什么时候会触发强缓存或者协商缓存?

1.强缓存
强缓存离不开两个响应头Expires与Cache-Control

①Expires:Expires是http1.0提出的一个表示资源过期时间的header,它描述的是一个绝对时间,由服务器返回,Expires受限于本地时间,如果修改了本地时间,可能会造成缓存失效。

格式:Expires:Wed,11 May 2020 10:34:00 GMT

②Cache-Control:Cache-Control 出现于HTTP/1.1,优先级高于Expires,表示的是相对时间

格式:Cache-Control:max-age=315360000

目前主流的做法使用Cache-Control控制缓存,除了max-age控制时间外,还有不得不提

①Cache-Control:public 可以被所有用户缓存,包括终端和CDN等中间代理服务器。

②Cache-Control:private 只能被终端浏览器缓存,不允许中继缓存服务器进行缓存。

③Cache-Control:no-cache 先缓存本地,但是在命中缓存后必须与服务器验证缓存的新鲜度才能使用。

④Cache-Control:no-store 不会产生任何缓存。
在这里插入图片描述
在缓存有效期内命名命中缓存,浏览器会直接读取本地的缓存资源,当缓存过期之后会与服务器进行协商。

2.协商缓存
当第一次请求时服务器返回的响应头中没有Cache-Control和Expires或者Cache-Control和Expires过期亦或它的属性设置为no-cache时,那么浏览器第二次请求时就会与服务器进行协商。

如果缓存和服务器资源的最新版本是一致的,那么就无需再次下载该资源,服务器直接返回304 Not Modified 状态码,如果服务器发现浏览器中的缓存已经是旧版本了,那么服务器就会把最新资源的完整内容返回浏览器,状态码就是200 OK。

服务器判断缓存是否新鲜的方法就是依靠HTTP的另外两组信息。

Last-Modified/If-Modified-Since

客户端首次请求资源时,服务器会把资源的最新修改时间 Last-Modified:Thu,19 Feb 2020 08:23:23 GMT 通过响应头首发送给客户端,当再次发送请求时,客户端将服务器返回的修改时间放在请求头If-Modified-Since: Thu, 19 Feb 2020 08:23:23 GMT 发送给服务器,服务器再跟服务器上的对应的资源进行对比,如果服务器的资源跟新,那么返回最新的资源,此时状态码200,当服务器资源跟客户端请求的首部时间一致,证明客户端的资源是跟新的,返回304状态码,表示客户端直接用缓存即可。

ETag/If-None-Match

ETag的流程跟Last-Modified是类似的,区别就在于ETag是根据资源内容进行hash,生成一个信息摘要,只要资源内容有变化,这个再要就会发生巨变,通过这个摘要信息对比,即可确定客户端的缓存资源是否为更新,这比Last-Modified的精确度要更高。

响应头:
在这里插入图片描述
因此整体的缓存流程图如下:
在这里插入图片描述

猜你喜欢

转载自blog.csdn.net/imagine_tion/article/details/110422884