通过指定通用首部字段Cache-Control的命令,就能操作缓存的工作机制。
首部字段Cache-Control可以应用于请求和响应时,指数参数是可选的,多个参数之间使用“,”进行分隔。
1>请求命令一览表:
2>响应指令一览表:
各种指令对比解释:
-
public指令 除了指定用户外,其他用户也可以保存这份缓存。
-
private指令 响应只以特定的用户为对象。缓存服务器会对该特定用户提供资源缓存的服务,对于其他用户发送过来的请求,代理服务器则不会返回缓存。
-
no-cache指令 使用该指令的目的是为了防止从缓存中返回过期资源。客户端发送的请求中如果包含了该指令,则表示客户端将不会接收缓存过的响应。于是,“中间”的缓存服务器必须把客户端请求转发给源服务器。如果源服务器返回的响应中包含该指令,则表明缓存服务器不能对该资源进行缓存。而且源服务器以后也不会对缓存服务器请求中提出的资源有效性进行确认,且禁止其对响应资源进行缓存操作。
-
no-store指令 当使用no-store指令时,暗示请求(和对应的响应)或者响应中包含机密信息。因此,该指令规定缓存不能在本地存储请求或响应的任一部分。该指令很容易和no-cache指令混淆,其实no-cache指令代表的是不缓存过期的资源,缓存会向源服务器进行有效期确认后处理资源。所以称为do-not-server-from-cache-without-revalidation更加合适
-
max-age指令 当客户端发送的请求中包含max-age指令时,如果判定缓存资源的缓存时间数值比指定时间的数值更小,那么客户端就接收缓存的资源。当指定max-age为0时,缓存服务器通常需要将请求转发给源服务器。当源服务器返回的响应中包含max-age指令时,缓存服务器将不对资源的有效性再作确认,而max-age数值代表资源保存为缓存的最长时间。
-
s-maxage指令 该指令的功能和max-age指令的相同,他们的不同点是该指令只适用于供应多位用户的公共缓存服务器,也就是说,对于向同一用户重复返回响应的服务器来说,这个指令没有作用。
-
min-fresh指令 该指令要求缓存服务器返回至少还未过指定时间的缓存资源。比如当指定min-fresh为60秒后,过了60秒的资源都无法作为响应返回。
-
max-stale指令 该指令用于指示缓存资源,即使过期也照常接收。如果指令未指定参数值,那么无论经过多久,客户端都会接收响应。如果指令中指定了具体数值,那么即使过期,只要仍然处于max-stale指定的时间内,仍旧会被客户端接收。
-
only-if-cached指令 该指令表示客户端仅在缓存服务器本地缓存目标资源的情况下才会要求其返回。换言之,该指令要求缓存服务器不重新加载响应,也不会再次确认资源有效性。若发生请求缓存服务器的本地缓存无响应,则返回状态码504 Gateway Timeout
-
must-revalidate指令 如果使用该指令,代理会向源服务器再次验证即将返回的响应缓存目前是否仍然有效。若代理无法连通源服务器再次获取有效资源的话,缓存必须给客户端一条504状态码。另外,使用了该指令意味着会忽略请求的max-stale指令。
-
proxy-revalidate指令 使用该指令要求所有的缓存服务器在接收到客户端带有该指令的请求返回响应前,必须再次验证缓存的有效性。
-
no-transform指令 使用该指令规定无论是在请求还是响应中,缓存都不能改变实体主体的媒体类型。这样做可以防止缓存或者代理压缩图片等类似操作。
-
cache-extension指令 token 通过cache-extension标记,可以拓展Cache-Control首部字段内的指令。如果缓存服务器不能理解拓展的新指令,就会直接忽视它。