draft-ietf-httpbis-p6-cache-01.txt | draft-ietf-httpbis-p6-cache-02.txt | |||
---|---|---|---|---|
Network Working Group R. Fielding, Ed. | Network Working Group R. Fielding, Ed. | |||
Internet-Draft Day Software | Internet-Draft Day Software | |||
Obsoletes: 2616 (if approved) J. Gettys | Obsoletes: 2616 (if approved) J. Gettys | |||
Intended status: Standards Track One Laptop per Child | Intended status: Standards Track One Laptop per Child | |||
Expires: July 15, 2008 J. Mogul | Expires: August 27, 2008 J. Mogul | |||
HP | HP | |||
H. Frystyk | H. Frystyk | |||
Microsoft | Microsoft | |||
L. Masinter | L. Masinter | |||
Adobe Systems | Adobe Systems | |||
P. Leach | P. Leach | |||
Microsoft | Microsoft | |||
T. Berners-Lee | T. Berners-Lee | |||
W3C/MIT | W3C/MIT | |||
Y. Lafon, Ed. | Y. Lafon, Ed. | |||
W3C | W3C | |||
J. Reschke, Ed. | J. Reschke, Ed. | |||
greenbytes | greenbytes | |||
January 12, 2008 | February 24, 2008 | |||
HTTP/1.1, part 6: Caching | HTTP/1.1, part 6: Caching | |||
draft-ietf-httpbis-p6-cache-01 | draft-ietf-httpbis-p6-cache-02 | |||
Status of this Memo | Status of this Memo | |||
By submitting this Internet-Draft, each author represents that any | By submitting this Internet-Draft, each author represents that any | |||
applicable patent or other IPR claims of which he or she is aware | applicable patent or other IPR claims of which he or she is aware | |||
have been or will be disclosed, and any of which he or she becomes | have been or will be disclosed, and any of which he or she becomes | |||
aware will be disclosed, in accordance with Section 6 of BCP 79. | aware will be disclosed, in accordance with Section 6 of BCP 79. | |||
Internet-Drafts are working documents of the Internet Engineering | Internet-Drafts are working documents of the Internet Engineering | |||
Task Force (IETF), its areas, and its working groups. Note that | Task Force (IETF), its areas, and its working groups. Note that | |||
skipping to change at page 1, line 49 | skipping to change at page 1, line 49 | |||
and may be updated, replaced, or obsoleted by other documents at any | and may be updated, replaced, or obsoleted by other documents at any | |||
time. It is inappropriate to use Internet-Drafts as reference | time. It is inappropriate to use Internet-Drafts as reference | |||
material or to cite them other than as "work in progress." | material or to cite them other than as "work in progress." | |||
The list of current Internet-Drafts can be accessed at | The list of current Internet-Drafts can be accessed at | |||
http://www.ietf.org/ietf/1id-abstracts.txt. | http://www.ietf.org/ietf/1id-abstracts.txt. | |||
The list of Internet-Draft Shadow Directories can be accessed at | The list of Internet-Draft Shadow Directories can be accessed at | |||
http://www.ietf.org/shadow.html. | http://www.ietf.org/shadow.html. | |||
This Internet-Draft will expire on July 15, 2008. | This Internet-Draft will expire on August 27, 2008. | |||
Copyright Notice | Copyright Notice | |||
Copyright (C) The IETF Trust (2008). | Copyright (C) The IETF Trust (2008). | |||
Abstract | Abstract | |||
The Hypertext Transfer Protocol (HTTP) is an application-level | The Hypertext Transfer Protocol (HTTP) is an application-level | |||
protocol for distributed, collaborative, hypermedia information | protocol for distributed, collaborative, hypermedia information | |||
systems. HTTP has been in use by the World Wide Web global | systems. HTTP has been in use by the World Wide Web global | |||
skipping to change at page 3, line 11 | skipping to change at page 3, line 11 | |||
(<http://purl.org/NET/http-errata>), or which were agreed upon on the | (<http://purl.org/NET/http-errata>), or which were agreed upon on the | |||
mailing list between October 2006 and November 2007 (as published in | mailing list between October 2006 and November 2007 (as published in | |||
"draft-lafon-rfc2616bis-03"). | "draft-lafon-rfc2616bis-03"). | |||
Table of Contents | Table of Contents | |||
1. Introduction . . . . . . . . . . . . . . . . . . . . . . . . . 5 | 1. Introduction . . . . . . . . . . . . . . . . . . . . . . . . . 5 | |||
1.1. Purpose . . . . . . . . . . . . . . . . . . . . . . . . . 5 | 1.1. Purpose . . . . . . . . . . . . . . . . . . . . . . . . . 5 | |||
1.2. Terminology . . . . . . . . . . . . . . . . . . . . . . . 6 | 1.2. Terminology . . . . . . . . . . . . . . . . . . . . . . . 6 | |||
1.3. Requirements . . . . . . . . . . . . . . . . . . . . . . . 7 | 1.3. Requirements . . . . . . . . . . . . . . . . . . . . . . . 7 | |||
2. Overview . . . . . . . . . . . . . . . . . . . . . . . . . . . 8 | 2. Notational Conventions and Generic Grammar . . . . . . . . . . 8 | |||
2.1. Cache Correctness . . . . . . . . . . . . . . . . . . . . 8 | 3. Overview . . . . . . . . . . . . . . . . . . . . . . . . . . . 8 | |||
2.2. Warnings . . . . . . . . . . . . . . . . . . . . . . . . . 8 | 3.1. Cache Correctness . . . . . . . . . . . . . . . . . . . . 8 | |||
2.3. Cache-control Mechanisms . . . . . . . . . . . . . . . . . 10 | 3.2. Warnings . . . . . . . . . . . . . . . . . . . . . . . . . 9 | |||
2.4. Explicit User Agent Warnings . . . . . . . . . . . . . . . 10 | 3.3. Cache-control Mechanisms . . . . . . . . . . . . . . . . . 10 | |||
2.5. Exceptions to the Rules and Warnings . . . . . . . . . . . 11 | 3.4. Explicit User Agent Warnings . . . . . . . . . . . . . . . 10 | |||
2.6. Client-controlled Behavior . . . . . . . . . . . . . . . . 11 | 3.5. Exceptions to the Rules and Warnings . . . . . . . . . . . 11 | |||
3. Expiration Model . . . . . . . . . . . . . . . . . . . . . . . 11 | 3.6. Client-controlled Behavior . . . . . . . . . . . . . . . . 11 | |||
3.1. Server-Specified Expiration . . . . . . . . . . . . . . . 11 | 4. Expiration Model . . . . . . . . . . . . . . . . . . . . . . . 12 | |||
3.2. Heuristic Expiration . . . . . . . . . . . . . . . . . . . 12 | 4.1. Server-Specified Expiration . . . . . . . . . . . . . . . 12 | |||
3.3. Age Calculations . . . . . . . . . . . . . . . . . . . . . 13 | 4.2. Heuristic Expiration . . . . . . . . . . . . . . . . . . . 13 | |||
3.4. Expiration Calculations . . . . . . . . . . . . . . . . . 15 | 4.3. Age Calculations . . . . . . . . . . . . . . . . . . . . . 13 | |||
3.5. Disambiguating Expiration Values . . . . . . . . . . . . . 16 | 4.4. Expiration Calculations . . . . . . . . . . . . . . . . . 15 | |||
3.6. Disambiguating Multiple Responses . . . . . . . . . . . . 16 | 4.5. Disambiguating Expiration Values . . . . . . . . . . . . . 16 | |||
4. Validation Model . . . . . . . . . . . . . . . . . . . . . . . 17 | 4.6. Disambiguating Multiple Responses . . . . . . . . . . . . 17 | |||
4.1. Last-Modified Dates . . . . . . . . . . . . . . . . . . . 18 | 5. Validation Model . . . . . . . . . . . . . . . . . . . . . . . 17 | |||
4.2. Entity Tag Cache Validators . . . . . . . . . . . . . . . 18 | 6. Response Cacheability . . . . . . . . . . . . . . . . . . . . 18 | |||
4.3. Non-validating Conditionals . . . . . . . . . . . . . . . 18 | 7. Constructing Responses From Caches . . . . . . . . . . . . . . 19 | |||
5. Response Cacheability . . . . . . . . . . . . . . . . . . . . 18 | 7.1. End-to-end and Hop-by-hop Headers . . . . . . . . . . . . 19 | |||
6. Constructing Responses From Caches . . . . . . . . . . . . . . 19 | 7.2. Non-modifiable Headers . . . . . . . . . . . . . . . . . . 20 | |||
6.1. End-to-end and Hop-by-hop Headers . . . . . . . . . . . . 19 | 7.3. Combining Headers . . . . . . . . . . . . . . . . . . . . 21 | |||
6.2. Non-modifiable Headers . . . . . . . . . . . . . . . . . . 20 | 8. Caching Negotiated Responses . . . . . . . . . . . . . . . . . 22 | |||
6.3. Combining Headers . . . . . . . . . . . . . . . . . . . . 21 | 9. Shared and Non-Shared Caches . . . . . . . . . . . . . . . . . 23 | |||
7. Caching Negotiated Responses . . . . . . . . . . . . . . . . . 22 | 10. Errors or Incomplete Response Cache Behavior . . . . . . . . . 24 | |||
8. Shared and Non-Shared Caches . . . . . . . . . . . . . . . . . 24 | 11. Side Effects of GET and HEAD . . . . . . . . . . . . . . . . . 24 | |||
9. Errors or Incomplete Response Cache Behavior . . . . . . . . . 24 | 12. Invalidation After Updates or Deletions . . . . . . . . . . . 24 | |||
10. Side Effects of GET and HEAD . . . . . . . . . . . . . . . . . 24 | 13. Write-Through Mandatory . . . . . . . . . . . . . . . . . . . 25 | |||
11. Invalidation After Updates or Deletions . . . . . . . . . . . 25 | 14. Cache Replacement . . . . . . . . . . . . . . . . . . . . . . 26 | |||
12. Write-Through Mandatory . . . . . . . . . . . . . . . . . . . 26 | 15. History Lists . . . . . . . . . . . . . . . . . . . . . . . . 26 | |||
13. Cache Replacement . . . . . . . . . . . . . . . . . . . . . . 26 | 16. Header Field Definitions . . . . . . . . . . . . . . . . . . . 27 | |||
14. History Lists . . . . . . . . . . . . . . . . . . . . . . . . 26 | 16.1. Age . . . . . . . . . . . . . . . . . . . . . . . . . . . 27 | |||
15. Header Field Definitions . . . . . . . . . . . . . . . . . . . 27 | 16.2. Cache-Control . . . . . . . . . . . . . . . . . . . . . . 27 | |||
15.1. Age . . . . . . . . . . . . . . . . . . . . . . . . . . . 27 | 16.2.1. What is Cacheable . . . . . . . . . . . . . . . . . . 29 | |||
15.2. Cache-Control . . . . . . . . . . . . . . . . . . . . . . 28 | 16.2.2. What May be Stored by Caches . . . . . . . . . . . . 30 | |||
15.2.1. What is Cacheable . . . . . . . . . . . . . . . . . . 30 | 16.2.3. Modifications of the Basic Expiration Mechanism . . . 31 | |||
15.2.2. What May be Stored by Caches . . . . . . . . . . . . 31 | 16.2.4. Cache Revalidation and Reload Controls . . . . . . . 33 | |||
15.2.3. Modifications of the Basic Expiration Mechanism . . . 31 | 16.2.5. No-Transform Directive . . . . . . . . . . . . . . . 35 | |||
15.2.4. Cache Revalidation and Reload Controls . . . . . . . 33 | 16.2.6. Cache Control Extensions . . . . . . . . . . . . . . 36 | |||
15.2.5. No-Transform Directive . . . . . . . . . . . . . . . 36 | 16.3. Expires . . . . . . . . . . . . . . . . . . . . . . . . . 37 | |||
15.2.6. Cache Control Extensions . . . . . . . . . . . . . . 37 | 16.4. Pragma . . . . . . . . . . . . . . . . . . . . . . . . . . 38 | |||
15.3. Expires . . . . . . . . . . . . . . . . . . . . . . . . . 37 | 16.5. Vary . . . . . . . . . . . . . . . . . . . . . . . . . . . 38 | |||
15.4. Pragma . . . . . . . . . . . . . . . . . . . . . . . . . . 38 | 16.6. Warning . . . . . . . . . . . . . . . . . . . . . . . . . 39 | |||
15.5. Vary . . . . . . . . . . . . . . . . . . . . . . . . . . . 39 | 17. IANA Considerations . . . . . . . . . . . . . . . . . . . . . 42 | |||
15.6. Warning . . . . . . . . . . . . . . . . . . . . . . . . . 40 | 18. Security Considerations . . . . . . . . . . . . . . . . . . . 42 | |||
16. IANA Considerations . . . . . . . . . . . . . . . . . . . . . 43 | 19. Acknowledgments . . . . . . . . . . . . . . . . . . . . . . . 42 | |||
17. Security Considerations . . . . . . . . . . . . . . . . . . . 43 | 20. References . . . . . . . . . . . . . . . . . . . . . . . . . . 42 | |||
18. Acknowledgments . . . . . . . . . . . . . . . . . . . . . . . 43 | 20.1. Normative References . . . . . . . . . . . . . . . . . . . 42 | |||
19. References . . . . . . . . . . . . . . . . . . . . . . . . . . 43 | 20.2. Informative References . . . . . . . . . . . . . . . . . . 44 | |||
19.1. Normative References . . . . . . . . . . . . . . . . . . . 43 | ||||
19.2. Informative References . . . . . . . . . . . . . . . . . . 44 | ||||
Appendix A. Compatibility with Previous Versions . . . . . . . . 44 | Appendix A. Compatibility with Previous Versions . . . . . . . . 44 | |||
A.1. Changes from RFC 2068 . . . . . . . . . . . . . . . . . . 44 | A.1. Changes from RFC 2068 . . . . . . . . . . . . . . . . . . 44 | |||
A.2. Changes from RFC 2616 . . . . . . . . . . . . . . . . . . 45 | A.2. Changes from RFC 2616 . . . . . . . . . . . . . . . . . . 44 | |||
Appendix B. Change Log (to be removed by RFC Editor before | Appendix B. Change Log (to be removed by RFC Editor before | |||
publication) . . . . . . . . . . . . . . . . . . . . 45 | publication) . . . . . . . . . . . . . . . . . . . . 44 | |||
B.1. Since RFC2616 . . . . . . . . . . . . . . . . . . . . . . 45 | B.1. Since RFC2616 . . . . . . . . . . . . . . . . . . . . . . 45 | |||
B.2. Since draft-ietf-httpbis-p6-cache-00 . . . . . . . . . . . 45 | B.2. Since draft-ietf-httpbis-p6-cache-00 . . . . . . . . . . . 45 | |||
B.3. Since draft-ietf-httpbis-p6-cache-01 . . . . . . . . . . . 45 | ||||
Index . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 46 | Index . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 46 | |||
Authors' Addresses . . . . . . . . . . . . . . . . . . . . . . . . 48 | Authors' Addresses . . . . . . . . . . . . . . . . . . . . . . . . 48 | |||
Intellectual Property and Copyright Statements . . . . . . . . . . 52 | Intellectual Property and Copyright Statements . . . . . . . . . . 51 | |||
1. Introduction | 1. Introduction | |||
HTTP is typically used for distributed information systems, where | HTTP is typically used for distributed information systems, where | |||
performance can be improved by the use of response caches, and | performance can be improved by the use of response caches, and | |||
includes a number of elements intended to make caching work as well | includes a number of elements intended to make caching work as well | |||
as possible. Because these elements interact with each other, it is | as possible. Because these elements interact with each other, it is | |||
useful to describe the caching design of HTTP separately. This | useful to describe the caching design of HTTP separately. This | |||
document defines aspects of HTTP/1.1 related to caching and reusing | document defines aspects of HTTP/1.1 related to caching and reusing | |||
response messages. | response messages. | |||
skipping to change at page 5, line 25 | skipping to change at page 5, line 25 | |||
1.1. Purpose | 1.1. Purpose | |||
An HTTP cache is a local store of response messages and the subsystem | An HTTP cache is a local store of response messages and the subsystem | |||
that controls its message storage, retrieval, and deletion. A cache | that controls its message storage, retrieval, and deletion. A cache | |||
stores cacheable responses in order to reduce the response time and | stores cacheable responses in order to reduce the response time and | |||
network bandwidth consumption on future, equivalent requests. Any | network bandwidth consumption on future, equivalent requests. Any | |||
client or server may include a cache, though a cache cannot be used | client or server may include a cache, though a cache cannot be used | |||
by a server that is acting as a tunnel. | by a server that is acting as a tunnel. | |||
Caching would be useless if it did not significantly improve | Caching would be useless if it did not significantly improve | |||
performance. The goal of caching in HTTP/1.1 is to eliminate the | performance. The goal of caching in HTTP/1.1 is to reuse a prior | |||
need to send requests in many cases, and to eliminate the need to | response message to satisfy a current request. In some cases, the | |||
send full responses in many other cases. The former reduces the | existing response can be reused without the need for a network | |||
number of network round-trips required for many operations; we use an | request, reducing latency and network round-trips; we use an | |||
"expiration" mechanism for this purpose (see Section 3). The latter | "expiration" mechanism for this purpose (see Section 4). Even when a | |||
reduces network bandwidth requirements; we use a "validation" | new request is required, it is often possible to reuse all or parts | |||
mechanism for this purpose (see Section 4). | of the payload of a prior response to satisfy the request, thereby | |||
reducing network bandwidth usage; we use a "validation" mechanism for | ||||
this purpose (see Section 5). | ||||
A cache behaves in a "semantically transparent" manner, with respect | A cache behaves in a "semantically transparent" manner, with respect | |||
to a particular response, when its use affects neither the requesting | to a particular response, when its use affects neither the requesting | |||
client nor the origin server, except to improve performance. When a | client nor the origin server, except to improve performance. When a | |||
cache is semantically transparent, the client receives exactly the | cache is semantically transparent, the client receives exactly the | |||
same response (except for hop-by-hop headers) that it would have | same response status and payload that it would have received had its | |||
received had its request been handled directly by the origin server. | request been handled directly by the origin server. | |||
In an ideal world, all interactions with an HTTP cache would be | In an ideal world, all interactions with an HTTP cache would be | |||
semantically transparent. However, for some resources, semantic | semantically transparent. However, for some resources, semantic | |||
transparency is not always necessary and can be effectively traded | transparency is not always necessary and can be effectively traded | |||
for the sake of bandwidth scaling, disconnected operation, and high | for the sake of bandwidth scaling, disconnected operation, and high | |||
availability. HTTP/1.1 allows origin servers, caches, and clients to | availability. HTTP/1.1 allows origin servers, caches, and clients to | |||
explicitly reduce transparency when necessary. However, because non- | explicitly reduce transparency when necessary. However, because non- | |||
transparent operation may confuse non-expert users and might be | transparent operation may confuse non-expert users and might be | |||
incompatible with certain server applications (such as those for | incompatible with certain server applications (such as those for | |||
ordering merchandise), the protocol requires that transparency be | ordering merchandise), the protocol requires that transparency be | |||
skipping to change at page 6, line 38 | skipping to change at page 6, line 41 | |||
1.2. Terminology | 1.2. Terminology | |||
This specification uses a number of terms to refer to the roles | This specification uses a number of terms to refer to the roles | |||
played by participants in, and objects of, HTTP caching. | played by participants in, and objects of, HTTP caching. | |||
cacheable | cacheable | |||
A response is cacheable if a cache is allowed to store a copy of | A response is cacheable if a cache is allowed to store a copy of | |||
the response message for use in answering subsequent requests. | the response message for use in answering subsequent requests. | |||
Even if a resource is cacheable, there may be additional | Even when a response is cacheable, there may be additional | |||
constraints on whether a cache can use the cached copy for a | constraints on whether a cache can use the cached copy for a | |||
particular request. | particular request. | |||
first-hand | first-hand | |||
A response is first-hand if it comes directly and without | A response is first-hand if it comes directly and without | |||
unnecessary delay from the origin server, perhaps via one or more | unnecessary delay from the origin server, perhaps via one or more | |||
proxies. A response is also first-hand if its validity has just | proxies. A response is also first-hand if its validity has just | |||
been checked directly with the origin server. | been checked directly with the origin server. | |||
skipping to change at page 8, line 5 | skipping to change at page 8, line 6 | |||
An implementation is not compliant if it fails to satisfy one or more | An implementation is not compliant if it fails to satisfy one or more | |||
of the MUST or REQUIRED level requirements for the protocols it | of the MUST or REQUIRED level requirements for the protocols it | |||
implements. An implementation that satisfies all the MUST or | implements. An implementation that satisfies all the MUST or | |||
REQUIRED level and all the SHOULD level requirements for its | REQUIRED level and all the SHOULD level requirements for its | |||
protocols is said to be "unconditionally compliant"; one that | protocols is said to be "unconditionally compliant"; one that | |||
satisfies all the MUST level requirements but not all the SHOULD | satisfies all the MUST level requirements but not all the SHOULD | |||
level requirements for its protocols is said to be "conditionally | level requirements for its protocols is said to be "conditionally | |||
compliant." | compliant." | |||
2. Overview | 2. Notational Conventions and Generic Grammar | |||
2.1. Cache Correctness | This specification uses the ABNF syntax defined in Section 2.1 of | |||
[Part1] and the core rules defined in Section 2.2 of [Part1]: | ||||
[[abnf.dep: ABNF syntax and basic rules will be adopted from RFC | ||||
5234, see <http://tools.ietf.org/wg/httpbis/trac/ticket/36>.]] | ||||
DIGIT = <DIGIT, defined in [Part1], Section 2.2> | ||||
DQUOTE = <DQUOTE, defined in [Part1], Section 2.2> | ||||
SP = <SP, defined in [Part1], Section 2.2> | ||||
quoted-string = <quoted-string, defined in [Part1], Section 2.2> | ||||
token = <token, defined in [Part1], Section 2.2> | ||||
The ABNF rules below are defined in other parts: | ||||
field-name = <field-name, defined in [Part1], Section 4.2> | ||||
HTTP-date = <HTTP-date, defined in [Part1], Section 3.3.1> | ||||
port = <port, defined in [Part1], Section 3.2.1> | ||||
pseudonym = <pseudonym, defined in [Part1], Section 8.9> | ||||
uri-host = <uri-host, defined in [Part1], Section 3.2.1> | ||||
3. Overview | ||||
3.1. Cache Correctness | ||||
A correct cache MUST respond to a request with the most up-to-date | A correct cache MUST respond to a request with the most up-to-date | |||
response held by the cache that is appropriate to the request (see | response held by the cache that is appropriate to the request (see | |||
Sections 3.5, 3.6, and 13) which meets one of the following | Sections 4.5, 4.6, and 14) which meets one of the following | |||
conditions: | conditions: | |||
1. It has been checked for equivalence with what the origin server | 1. It has been checked for equivalence with what the origin server | |||
would have returned by revalidating the response with the origin | would have returned by revalidating the response with the origin | |||
server (Section 4); | server (Section 5); | |||
2. It is "fresh enough" (see Section 3). In the default case, this | 2. It is "fresh enough" (see Section 4). In the default case, this | |||
means it meets the least restrictive freshness requirement of the | means it meets the least restrictive freshness requirement of the | |||
client, origin server, and cache (see Section 15.2); if the | client, origin server, and cache (see Section 16.2); if the | |||
origin server so specifies, it is the freshness requirement of | origin server so specifies, it is the freshness requirement of | |||
the origin server alone. If a stored response is not "fresh | the origin server alone. If a stored response is not "fresh | |||
enough" by the most restrictive freshness requirement of both the | enough" by the most restrictive freshness requirement of both the | |||
client and the origin server, in carefully considered | client and the origin server, in carefully considered | |||
circumstances the cache MAY still return the response with the | circumstances the cache MAY still return the response with the | |||
appropriate Warning header (see Sections 2.5 and 15.6), unless | appropriate Warning header (see Sections 3.5 and 16.6), unless | |||
such a response is prohibited (e.g., by a "no-store" cache- | such a response is prohibited (e.g., by a "no-store" cache- | |||
directive, or by a "no-cache" cache-request-directive; see | directive, or by a "no-cache" cache-request-directive; see | |||
Section 15.2). | Section 16.2). | |||
3. It is an appropriate 304 (Not Modified), 305 (Use Proxy), or | 3. It is an appropriate 304 (Not Modified), 305 (Use Proxy), or | |||
error (4xx or 5xx) response message. | error (4xx or 5xx) response message. | |||
If the cache can not communicate with the origin server, then a | If the cache can not communicate with the origin server, then a | |||
correct cache SHOULD respond as above if the response can be | correct cache SHOULD respond as above if the response can be | |||
correctly served from the cache; if not it MUST return an error or | correctly served from the cache; if not it MUST return an error or | |||
warning indicating that there was a communication failure. | warning indicating that there was a communication failure. | |||
If a cache receives a response (either an entire response, or a 304 | If a cache receives a response (either an entire response, or a 304 | |||
(Not Modified) response) that it would normally forward to the | (Not Modified) response) that it would normally forward to the | |||
requesting client, and the received response is no longer fresh, the | requesting client, and the received response is no longer fresh, the | |||
cache SHOULD forward it to the requesting client without adding a new | cache SHOULD forward it to the requesting client without adding a new | |||
Warning (but without removing any existing Warning headers). A cache | Warning (but without removing any existing Warning headers). A cache | |||
SHOULD NOT attempt to revalidate a response simply because that | SHOULD NOT attempt to revalidate a response simply because that | |||
response became stale in transit; this might lead to an infinite | response became stale in transit; this might lead to an infinite | |||
loop. A user agent that receives a stale response without a Warning | loop. A user agent that receives a stale response without a Warning | |||
MAY display a warning indication to the user. | MAY display a warning indication to the user. | |||
2.2. Warnings | 3.2. Warnings | |||
Whenever a cache returns a response that is neither first-hand nor | Whenever a cache returns a response that is neither first-hand nor | |||
"fresh enough" (in the sense of condition 2 in Section 2.1), it MUST | "fresh enough" (in the sense of condition 2 in Section 3.1), it MUST | |||
attach a warning to that effect, using a Warning general-header. The | attach a warning to that effect, using a Warning general-header. The | |||
Warning header and the currently defined warnings are described in | Warning header and the currently defined warnings are described in | |||
Section 15.6. The warning allows clients to take appropriate action. | Section 16.6. The warning allows clients to take appropriate action. | |||
Warnings MAY be used for other purposes, both cache-related and | Warnings MAY be used for other purposes, both cache-related and | |||
otherwise. The use of a warning, rather than an error status code, | otherwise. The use of a warning, rather than an error status code, | |||
distinguish these responses from true failures. | distinguish these responses from true failures. | |||
Warnings are assigned three digit warn-codes. The first digit | Warnings are assigned three digit warn-codes. The first digit | |||
indicates whether the Warning MUST or MUST NOT be deleted from a | indicates whether the Warning MUST or MUST NOT be deleted from a | |||
stored cache entry after a successful revalidation: | stored cache entry after a successful revalidation: | |||
1xx Warnings that describe the freshness or revalidation status of | 1xx Warnings that describe the freshness or revalidation status of | |||
the response, and so MUST be deleted after a successful | the response, and so MUST be deleted after a successful | |||
revalidation. 1xx warn-codes MAY be generated by a cache only when | revalidation. 1xx warn-codes MAY be generated by a cache only when | |||
validating a cached entry. It MUST NOT be generated by clients. | validating a cached entry. It MUST NOT be generated by clients. | |||
2xx Warnings that describe some aspect of the entity body or entity | 2xx Warnings that describe some aspect of the entity body or entity | |||
headers that is not rectified by a revalidation (for example, a | headers that is not rectified by a revalidation (for example, a | |||
lossy compression of the entity bodies) and which MUST NOT be | lossy compression of the entity bodies) and which MUST NOT be | |||
deleted after a successful revalidation. | deleted after a successful revalidation. | |||
See Section 15.6 for the definitions of the codes themselves. | See Section 16.6 for the definitions of the codes themselves. | |||
HTTP/1.0 caches will cache all Warnings in responses, without | HTTP/1.0 caches will cache all Warnings in responses, without | |||
deleting the ones in the first category. Warnings in responses that | deleting the ones in the first category. Warnings in responses that | |||
are passed to HTTP/1.0 caches carry an extra warning-date field, | are passed to HTTP/1.0 caches carry an extra warning-date field, | |||
which prevents a future HTTP/1.1 recipient from believing an | which prevents a future HTTP/1.1 recipient from believing an | |||
erroneously cached Warning. | erroneously cached Warning. | |||
Warnings also carry a warning text. The text MAY be in any | Warnings also carry a warning text. The text MAY be in any | |||
appropriate natural language (perhaps based on the client's Accept | appropriate natural language (perhaps based on the client's Accept | |||
headers), and include an OPTIONAL indication of what character set is | headers), and include an OPTIONAL indication of what character set is | |||
skipping to change at page 10, line 5 | skipping to change at page 10, line 29 | |||
server or by a cache), including multiple warnings with the same code | server or by a cache), including multiple warnings with the same code | |||
number. For example, a server might provide the same warning with | number. For example, a server might provide the same warning with | |||
texts in both English and Basque. | texts in both English and Basque. | |||
When multiple warnings are attached to a response, it might not be | When multiple warnings are attached to a response, it might not be | |||
practical or reasonable to display all of them to the user. This | practical or reasonable to display all of them to the user. This | |||
version of HTTP does not specify strict priority rules for deciding | version of HTTP does not specify strict priority rules for deciding | |||
which warnings to display and in what order, but does suggest some | which warnings to display and in what order, but does suggest some | |||
heuristics. | heuristics. | |||
2.3. Cache-control Mechanisms | 3.3. Cache-control Mechanisms | |||
The basic cache mechanisms in HTTP/1.1 (server-specified expiration | The basic cache mechanisms in HTTP/1.1 (server-specified expiration | |||
times and validators) are implicit directives to caches. In some | times and validators) are implicit directives to caches. In some | |||
cases, a server or client might need to provide explicit directives | cases, a server or client might need to provide explicit directives | |||
to the HTTP caches. We use the Cache-Control header for this | to the HTTP caches. We use the Cache-Control header for this | |||
purpose. | purpose. | |||
The Cache-Control header allows a client or server to transmit a | The Cache-Control header allows a client or server to transmit a | |||
variety of directives in either requests or responses. These | variety of directives in either requests or responses. These | |||
directives typically override the default caching algorithms. As a | directives typically override the default caching algorithms. As a | |||
general rule, if there is any apparent conflict between header | general rule, if there is any apparent conflict between header | |||
values, the most restrictive interpretation is applied (that is, the | values, the most restrictive interpretation is applied (that is, the | |||
one that is most likely to preserve semantic transparency). However, | one that is most likely to preserve semantic transparency). However, | |||
in some cases, cache-control directives are explicitly specified as | in some cases, cache-control directives are explicitly specified as | |||
weakening the approximation of semantic transparency (for example, | weakening the approximation of semantic transparency (for example, | |||
"max-stale" or "public"). | "max-stale" or "public"). | |||
The cache-control directives are described in detail in Section 15.2. | The cache-control directives are described in detail in Section 16.2. | |||
2.4. Explicit User Agent Warnings | 3.4. Explicit User Agent Warnings | |||
Many user agents make it possible for users to override the basic | Many user agents make it possible for users to override the basic | |||
caching mechanisms. For example, the user agent might allow the user | caching mechanisms. For example, the user agent might allow the user | |||
to specify that cached entities (even explicitly stale ones) are | to specify that cached entities (even explicitly stale ones) are | |||
never validated. Or the user agent might habitually add "Cache- | never validated. Or the user agent might habitually add "Cache- | |||
Control: max-stale=3600" to every request. The user agent SHOULD NOT | Control: max-stale=3600" to every request. The user agent SHOULD NOT | |||
default to either non-transparent behavior, or behavior that results | default to either non-transparent behavior, or behavior that results | |||
in abnormally ineffective caching, but MAY be explicitly configured | in abnormally ineffective caching, but MAY be explicitly configured | |||
to do so by an explicit action of the user. | to do so by an explicit action of the user. | |||
skipping to change at page 11, line 5 | skipping to change at page 11, line 28 | |||
need not be a dialog box; it could be an icon (for example, a picture | need not be a dialog box; it could be an icon (for example, a picture | |||
of a rotting fish) or some other indicator. | of a rotting fish) or some other indicator. | |||
If the user has overridden the caching mechanisms in a way that would | If the user has overridden the caching mechanisms in a way that would | |||
abnormally reduce the effectiveness of caches, the user agent SHOULD | abnormally reduce the effectiveness of caches, the user agent SHOULD | |||
continually indicate this state to the user (for example, by a | continually indicate this state to the user (for example, by a | |||
display of a picture of currency in flames) so that the user does not | display of a picture of currency in flames) so that the user does not | |||
inadvertently consume excess resources or suffer from excessive | inadvertently consume excess resources or suffer from excessive | |||
latency. | latency. | |||
2.5. Exceptions to the Rules and Warnings | 3.5. Exceptions to the Rules and Warnings | |||
In some cases, the operator of a cache MAY choose to configure it to | In some cases, the operator of a cache MAY choose to configure it to | |||
return stale responses even when not requested by clients. This | return stale responses even when not requested by clients. This | |||
decision ought not be made lightly, but may be necessary for reasons | decision ought not be made lightly, but may be necessary for reasons | |||
of availability or performance, especially when the cache is poorly | of availability or performance, especially when the cache is poorly | |||
connected to the origin server. Whenever a cache returns a stale | connected to the origin server. Whenever a cache returns a stale | |||
response, it MUST mark it as such (using a Warning header) enabling | response, it MUST mark it as such (using a Warning header) enabling | |||
the client software to alert the user that there might be a potential | the client software to alert the user that there might be a potential | |||
problem. | problem. | |||
It also allows the user agent to take steps to obtain a first-hand or | It also allows the user agent to take steps to obtain a first-hand or | |||
fresh response. For this reason, a cache SHOULD NOT return a stale | fresh response. For this reason, a cache SHOULD NOT return a stale | |||
response if the client explicitly requests a first-hand or fresh one, | response if the client explicitly requests a first-hand or fresh one, | |||
unless it is impossible to comply for technical or policy reasons. | unless it is impossible to comply for technical or policy reasons. | |||
2.6. Client-controlled Behavior | 3.6. Client-controlled Behavior | |||
While the origin server (and to a lesser extent, intermediate caches, | While the origin server (and to a lesser extent, intermediate caches, | |||
by their contribution to the age of a response) are the primary | by their contribution to the age of a response) are the primary | |||
source of expiration information, in some cases the client might need | source of expiration information, in some cases the client might need | |||
to control a cache's decision about whether to return a cached | to control a cache's decision about whether to return a cached | |||
response without validating it. Clients do this using several | response without validating it. Clients do this using several | |||
directives of the Cache-Control header. | directives of the Cache-Control header. | |||
A client's request MAY specify the maximum age it is willing to | A client's request MAY specify the maximum age it is willing to | |||
accept of an unvalidated response; specifying a value of zero forces | accept of an unvalidated response; specifying a value of zero forces | |||
skipping to change at page 11, line 44 | skipping to change at page 12, line 19 | |||
options increase constraints on the behavior of caches, and so cannot | options increase constraints on the behavior of caches, and so cannot | |||
further relax the cache's approximation of semantic transparency. | further relax the cache's approximation of semantic transparency. | |||
A client MAY also specify that it will accept stale responses, up to | A client MAY also specify that it will accept stale responses, up to | |||
some maximum amount of staleness. This loosens the constraints on | some maximum amount of staleness. This loosens the constraints on | |||
the caches, and so might violate the origin server's specified | the caches, and so might violate the origin server's specified | |||
constraints on semantic transparency, but might be necessary to | constraints on semantic transparency, but might be necessary to | |||
support disconnected operation, or high availability in the face of | support disconnected operation, or high availability in the face of | |||
poor connectivity. | poor connectivity. | |||
3. Expiration Model | 4. Expiration Model | |||
3.1. Server-Specified Expiration | 4.1. Server-Specified Expiration | |||
HTTP caching works best when caches can entirely avoid making | HTTP caching works best when caches can entirely avoid making | |||
requests to the origin server. The primary mechanism for avoiding | requests to the origin server. The primary mechanism for avoiding | |||
requests is for an origin server to provide an explicit expiration | requests is for an origin server to provide an explicit expiration | |||
time in the future, indicating that a response MAY be used to satisfy | time in the future, indicating that a response MAY be used to satisfy | |||
subsequent requests. In other words, a cache can return a fresh | subsequent requests. In other words, a cache can return a fresh | |||
response without first contacting the server. | response without first contacting the server. | |||
Our expectation is that servers will assign future explicit | Our expectation is that servers will assign future explicit | |||
expiration times to responses in the belief that the entity is not | expiration times to responses in the belief that the entity is not | |||
skipping to change at page 12, line 22 | skipping to change at page 12, line 45 | |||
chosen. | chosen. | |||
The expiration mechanism applies only to responses taken from a cache | The expiration mechanism applies only to responses taken from a cache | |||
and not to first-hand responses forwarded immediately to the | and not to first-hand responses forwarded immediately to the | |||
requesting client. | requesting client. | |||
If an origin server wishes to force a semantically transparent cache | If an origin server wishes to force a semantically transparent cache | |||
to validate every request, it MAY assign an explicit expiration time | to validate every request, it MAY assign an explicit expiration time | |||
in the past. This means that the response is always stale, and so | in the past. This means that the response is always stale, and so | |||
the cache SHOULD validate it before using it for subsequent requests. | the cache SHOULD validate it before using it for subsequent requests. | |||
See Section 15.2.4 for a more restrictive way to force revalidation. | See Section 16.2.4 for a more restrictive way to force revalidation. | |||
If an origin server wishes to force any HTTP/1.1 cache, no matter how | If an origin server wishes to force any HTTP/1.1 cache, no matter how | |||
it is configured, to validate every request, it SHOULD use the "must- | it is configured, to validate every request, it SHOULD use the "must- | |||
revalidate" cache-control directive (see Section 15.2). | revalidate" cache-control directive (see Section 16.2). | |||
Servers specify explicit expiration times using either the Expires | Servers specify explicit expiration times using either the Expires | |||
header, or the max-age directive of the Cache-Control header. | header, or the max-age directive of the Cache-Control header. | |||
An expiration time cannot be used to force a user agent to refresh | An expiration time cannot be used to force a user agent to refresh | |||
its display or reload a resource; its semantics apply only to caching | its display or reload a resource; its semantics apply only to caching | |||
mechanisms, and such mechanisms need only check a resource's | mechanisms, and such mechanisms need only check a resource's | |||
expiration status when a new request for that resource is initiated. | expiration status when a new request for that resource is initiated. | |||
See Section 14 for an explanation of the difference between caches | See Section 15 for an explanation of the difference between caches | |||
and history mechanisms. | and history mechanisms. | |||
3.2. Heuristic Expiration | 4.2. Heuristic Expiration | |||
Since origin servers do not always provide explicit expiration times, | Since origin servers do not always provide explicit expiration times, | |||
HTTP caches typically assign heuristic expiration times, employing | HTTP caches typically assign heuristic expiration times, employing | |||
algorithms that use other header values (such as the Last-Modified | algorithms that use other header values (such as the Last-Modified | |||
time) to estimate a plausible expiration time. The HTTP/1.1 | time) to estimate a plausible expiration time. The HTTP/1.1 | |||
specification does not provide specific algorithms, but does impose | specification does not provide specific algorithms, but does impose | |||
worst-case constraints on their results. Since heuristic expiration | worst-case constraints on their results. Since heuristic expiration | |||
times might compromise semantic transparency, they ought to be used | times might compromise semantic transparency, they ought to be used | |||
cautiously, and we encourage origin servers to provide explicit | cautiously, and we encourage origin servers to provide explicit | |||
expiration times as much as possible. | expiration times as much as possible. | |||
3.3. Age Calculations | 4.3. Age Calculations | |||
In order to know if a cached entry is fresh, a cache needs to know if | In order to know if a cached entry is fresh, a cache needs to know if | |||
its age exceeds its freshness lifetime. We discuss how to calculate | its age exceeds its freshness lifetime. We discuss how to calculate | |||
the latter in Section 3.4; this section describes how to calculate | the latter in Section 4.4; this section describes how to calculate | |||
the age of a response or cache entry. | the age of a response or cache entry. | |||
In this discussion, we use the term "now" to mean "the current value | In this discussion, we use the term "now" to mean "the current value | |||
of the clock at the host performing the calculation." Hosts that use | of the clock at the host performing the calculation." Hosts that use | |||
HTTP, but especially hosts running origin servers and caches, SHOULD | HTTP, but especially hosts running origin servers and caches, SHOULD | |||
use NTP [RFC1305] or some similar protocol to synchronize their | use NTP [RFC1305] or some similar protocol to synchronize their | |||
clocks to a globally accurate time standard. | clocks to a globally accurate time standard. | |||
HTTP/1.1 requires origin servers to send a Date header, if possible, | HTTP/1.1 requires origin servers to send a Date header, if possible, | |||
with every response, giving the time at which the response was | with every response, giving the time at which the response was | |||
skipping to change at page 15, line 16 | skipping to change at page 15, line 42 | |||
header field in the response with a value equal to the cache entry's | header field in the response with a value equal to the cache entry's | |||
current_age. | current_age. | |||
The presence of an Age header field in a response implies that a | The presence of an Age header field in a response implies that a | |||
response is not first-hand. However, the converse is not true, since | response is not first-hand. However, the converse is not true, since | |||
the lack of an Age header field in a response does not imply that the | the lack of an Age header field in a response does not imply that the | |||
response is first-hand unless all caches along the request path are | response is first-hand unless all caches along the request path are | |||
compliant with HTTP/1.1 (i.e., older HTTP caches did not implement | compliant with HTTP/1.1 (i.e., older HTTP caches did not implement | |||
the Age header field). | the Age header field). | |||
3.4. Expiration Calculations | 4.4. Expiration Calculations | |||
In order to decide whether a response is fresh or stale, we need to | In order to decide whether a response is fresh or stale, we need to | |||
compare its freshness lifetime to its age. The age is calculated as | compare its freshness lifetime to its age. The age is calculated as | |||
described in Section 3.3; this section describes how to calculate the | described in Section 4.3; this section describes how to calculate the | |||
freshness lifetime, and to determine if a response has expired. In | freshness lifetime, and to determine if a response has expired. In | |||
the discussion below, the values can be represented in any form | the discussion below, the values can be represented in any form | |||
appropriate for arithmetic operations. | appropriate for arithmetic operations. | |||
We use the term "expires_value" to denote the value of the Expires | We use the term "expires_value" to denote the value of the Expires | |||
header. We use the term "max_age_value" to denote an appropriate | header. We use the term "max_age_value" to denote an appropriate | |||
value of the number of seconds carried by the "max-age" directive of | value of the number of seconds carried by the "max-age" directive of | |||
the Cache-Control header in a response (see Section 15.2.3). | the Cache-Control header in a response (see Section 16.2.3). | |||
The max-age directive takes priority over Expires, so if max-age is | The max-age directive takes priority over Expires, so if max-age is | |||
present in a response, the calculation is simply: | present in a response, the calculation is simply: | |||
freshness_lifetime = max_age_value | freshness_lifetime = max_age_value | |||
Otherwise, if Expires is present in the response, the calculation is: | Otherwise, if Expires is present in the response, the calculation is: | |||
freshness_lifetime = expires_value - date_value | freshness_lifetime = expires_value - date_value | |||
Note that neither of these calculations is vulnerable to clock skew, | Note that neither of these calculations is vulnerable to clock skew, | |||
since all of the information comes from the origin server. | since all of the information comes from the origin server. | |||
If none of Expires, Cache-Control: max-age, or Cache-Control: | If none of Expires, Cache-Control: max-age, or Cache-Control: | |||
s-maxage (see Section 15.2.3) appears in the response, and the | s-maxage (see Section 16.2.3) appears in the response, and the | |||
response does not include other restrictions on caching, the cache | response does not include other restrictions on caching, the cache | |||
MAY compute a freshness lifetime using a heuristic. The cache MUST | MAY compute a freshness lifetime using a heuristic. The cache MUST | |||
attach Warning 113 to any response whose age is more than 24 hours if | attach Warning 113 to any response whose age is more than 24 hours if | |||
such warning has not already been added. | such warning has not already been added. | |||
Also, if the response does have a Last-Modified time, the heuristic | Also, if the response does have a Last-Modified time, the heuristic | |||
expiration value SHOULD be no more than some fraction of the interval | expiration value SHOULD be no more than some fraction of the interval | |||
since that time. A typical setting of this fraction might be 10%. | since that time. A typical setting of this fraction might be 10%. | |||
The calculation to determine if a response has expired is quite | The calculation to determine if a response has expired is quite | |||
simple: | simple: | |||
response_is_fresh = (freshness_lifetime > current_age) | response_is_fresh = (freshness_lifetime > current_age) | |||
3.5. Disambiguating Expiration Values | 4.5. Disambiguating Expiration Values | |||
Because expiration values are assigned optimistically, it is possible | Because expiration values are assigned optimistically, it is possible | |||
for two caches to contain fresh values for the same resource that are | for two caches to contain fresh values for the same resource that are | |||
different. | different. | |||
If a client performing a retrieval receives a non-first-hand response | If a client performing a retrieval receives a non-first-hand response | |||
for a request that was already fresh in its own cache, and the Date | for a request that was already fresh in its own cache, and the Date | |||
header in its existing cache entry is newer than the Date on the new | header in its existing cache entry is newer than the Date on the new | |||
response, then the client MAY ignore the response. If so, it MAY | response, then the client MAY ignore the response. If so, it MAY | |||
retry the request with a "Cache-Control: max-age=0" directive (see | retry the request with a "Cache-Control: max-age=0" directive (see | |||
Section 15.2), to force a check with the origin server. | Section 16.2), to force a check with the origin server. | |||
If a cache has two fresh responses for the same representation with | If a cache has two fresh responses for the same representation with | |||
different validators, it MUST use the one with the more recent Date | different validators, it MUST use the one with the more recent Date | |||
header. This situation might arise because the cache is pooling | header. This situation might arise because the cache is pooling | |||
responses from other caches, or because a client has asked for a | responses from other caches, or because a client has asked for a | |||
reload or a revalidation of an apparently fresh cache entry. | reload or a revalidation of an apparently fresh cache entry. | |||
3.6. Disambiguating Multiple Responses | 4.6. Disambiguating Multiple Responses | |||
Because a client might be receiving responses via multiple paths, so | Because a client might be receiving responses via multiple paths, so | |||
that some responses flow through one set of caches and other | that some responses flow through one set of caches and other | |||
responses flow through a different set of caches, a client might | responses flow through a different set of caches, a client might | |||
receive responses in an order different from that in which the origin | receive responses in an order different from that in which the origin | |||
server sent them. We would like the client to use the most recently | server sent them. We would like the client to use the most recently | |||
generated response, even if older responses are still apparently | generated response, even if older responses are still apparently | |||
fresh. | fresh. | |||
Neither the entity tag nor the expiration value can impose an | Neither the entity tag nor the expiration value can impose an | |||
skipping to change at page 17, line 15 | skipping to change at page 17, line 42 | |||
to force any intermediate caches to obtain a new copy from the origin | to force any intermediate caches to obtain a new copy from the origin | |||
server. | server. | |||
If the Date values are equal, then the client MAY use either response | If the Date values are equal, then the client MAY use either response | |||
(or MAY, if it is being extremely prudent, request a new response). | (or MAY, if it is being extremely prudent, request a new response). | |||
Servers MUST NOT depend on clients being able to choose | Servers MUST NOT depend on clients being able to choose | |||
deterministically between responses generated during the same second, | deterministically between responses generated during the same second, | |||
if their expiration times overlap. | if their expiration times overlap. | |||
4. Validation Model | 5. Validation Model | |||
When a cache has a stale entry that it would like to use as a | When a cache has a stale entry that it would like to use as a | |||
response to a client's request, it first has to check with the origin | response to a client's request, it first has to check with the origin | |||
server (or possibly an intermediate cache with a fresh response) to | server (or possibly an intermediate cache with a fresh response) to | |||
see if its cached entry is still usable. We call this "validating" | see if its cached entry is still usable. We call this "validating" | |||
the cache entry. Since we do not want to have to pay the overhead of | the cache entry. | |||
retransmitting the full response if the cached entry is good, and we | ||||
do not want to pay the overhead of an extra round trip if the cached | ||||
entry is invalid, the HTTP/1.1 protocol supports the use of | ||||
conditional methods. | ||||
The key protocol features for supporting conditional methods are | ||||
those concerned with "cache validators." When an origin server | ||||
generates a full response, it attaches some sort of validator to it, | ||||
which is kept with the cache entry. When a client (user agent or | ||||
proxy cache) makes a conditional request for a resource for which it | ||||
has a cache entry, it includes the associated validator in the | ||||
request. | ||||
The server then checks that validator against the current validator | ||||
for the entity, and, if they match (see Section 4 of [Part4]), it | ||||
responds with a special status code (usually, 304 (Not Modified)) and | ||||
no entity-body. Otherwise, it returns a full response (including | ||||
entity-body). Thus, we avoid transmitting the full response if the | ||||
validator matches, and we avoid an extra round trip if it does not | ||||
match. | ||||
In HTTP/1.1, a conditional request looks exactly the same as a normal | ||||
request for the same resource, except that it carries a special | ||||
header (which includes the validator) that implicitly turns the | ||||
method (usually, GET) into a conditional. | ||||
The protocol includes both positive and negative senses of cache- | ||||
validating conditions. That is, it is possible to request either | ||||
that a method be performed if and only if a validator matches or if | ||||
and only if no validators match. | ||||
Note: a response that lacks a validator may still be cached, and | ||||
served from cache until it expires, unless this is explicitly | ||||
prohibited by a cache-control directive. However, a cache cannot | ||||
do a conditional retrieval if it does not have a validator for the | ||||
entity, which means it will not be refreshable after it expires. | ||||
4.1. Last-Modified Dates | ||||
The Last-Modified entity-header field value is often used as a cache | ||||
validator. In simple terms, a cache entry is considered to be valid | ||||
if the entity has not been modified since the Last-Modified value. | ||||
4.2. Entity Tag Cache Validators | ||||
The ETag response-header field value, an entity tag, provides for an | ||||
"opaque" cache validator. This might allow more reliable validation | ||||
in situations where it is inconvenient to store modification dates, | ||||
where the one-second resolution of HTTP date values is not | ||||
sufficient, or where the origin server wishes to avoid certain | ||||
paradoxes that might arise from the use of modification dates. | ||||
Entity Tags are described in Section 2 of [Part4]. The headers used | ||||
with entity tags are described in Section 6 of [Part4]. | ||||
4.3. Non-validating Conditionals | ||||
The principle behind entity tags is that only the service author | HTTP's conditional request mechanism, defined in [Part4], is used to | |||
knows the semantics of a resource well enough to select an | avoid retransmitting the response payload when the cached entry is | |||
appropriate cache validation mechanism, and the specification of any | valid. When a cached response includes one or more "cache | |||
validator comparison function more complex than byte-equality would | validators," such as the field values of an ETag or Last-Modified | |||
open up a can of worms. Thus, comparisons of any other headers | header field, then a validating GET request SHOULD be made | |||
(except Last-Modified, for compatibility with HTTP/1.0) are never | conditional to those field values. The server checks the conditional | |||
used for purposes of validating a cache entry. | request's validator against the current state of the requested | |||
resource and, if they match, the server responds with a 304 (Not | ||||
Modified) status code to indicate that the cached response can be | ||||
refreshed and reused without retransmitting the response payload. If | ||||
the validator does not match the current state of the requested | ||||
resource, then the server returns a full response, including payload, | ||||
so that the request can be satisfied and the cache entry supplanted | ||||
without the need for an additional network round-trip. | ||||
5. Response Cacheability | 6. Response Cacheability | |||
Unless specifically constrained by a cache-control (Section 15.2) | Unless specifically constrained by a cache-control (Section 16.2) | |||
directive, a caching system MAY always store a successful response | directive, a caching system MAY always store a successful response | |||
(see Section 9) as a cache entry, MAY return it without validation if | (see Section 10) as a cache entry, MAY return it without validation | |||
it is fresh, and MAY return it after successful validation. If there | if it is fresh, and MAY return it after successful validation. If | |||
is neither a cache validator nor an explicit expiration time | there is neither a cache validator nor an explicit expiration time | |||
associated with a response, we do not expect it to be cached, but | associated with a response, we do not expect it to be cached, but | |||
certain caches MAY violate this expectation (for example, when little | certain caches MAY violate this expectation (for example, when little | |||
or no network connectivity is available). A client can usually | or no network connectivity is available). A client can usually | |||
detect that such a response was taken from a cache by comparing the | detect that such a response was taken from a cache by comparing the | |||
Date header to the current time. | Date header to the current time. | |||
Note: some HTTP/1.0 caches are known to violate this expectation | Note: some HTTP/1.0 caches are known to violate this expectation | |||
without providing any Warning. | without providing any Warning. | |||
However, in some cases it might be inappropriate for a cache to | However, in some cases it might be inappropriate for a cache to | |||
retain an entity, or to return it in response to a subsequent | retain an entity, or to return it in response to a subsequent | |||
request. This might be because absolute semantic transparency is | request. This might be because absolute semantic transparency is | |||
deemed necessary by the service author, or because of security or | deemed necessary by the service author, or because of security or | |||
privacy considerations. Certain cache-control directives are | privacy considerations. Certain cache-control directives are | |||
therefore provided so that the server can indicate that certain | therefore provided so that the server can indicate that certain | |||
resource entities, or portions thereof, are not to be cached | resource entities, or portions thereof, are not to be cached | |||
regardless of other considerations. | regardless of other considerations. | |||
Note that Section 3.1 of [Part7] normally prevents a shared cache | Note that Section 4.1 of [Part7] normally prevents a shared cache | |||
from saving and returning a response to a previous request if that | from saving and returning a response to a previous request if that | |||
request included an Authorization header. | request included an Authorization header. | |||
A response received with a status code of 200, 203, 206, 300, 301 or | A response received with a status code of 200, 203, 206, 300, 301 or | |||
410 MAY be stored by a cache and used in reply to a subsequent | 410 MAY be stored by a cache and used in reply to a subsequent | |||
request, subject to the expiration mechanism, unless a cache-control | request, subject to the expiration mechanism, unless a cache-control | |||
directive prohibits caching. However, a cache that does not support | directive prohibits caching. However, a cache that does not support | |||
the Range and Content-Range headers MUST NOT cache 206 (Partial | the Range and Content-Range headers MUST NOT cache 206 (Partial | |||
Content) responses. | Content) responses. | |||
A response received with any other status code (e.g. status codes 302 | A response received with any other status code (e.g. status codes 302 | |||
and 307) MUST NOT be returned in a reply to a subsequent request | and 307) MUST NOT be returned in a reply to a subsequent request | |||
unless there are cache-control directives or another header(s) that | unless there are cache-control directives or another header(s) that | |||
explicitly allow it. For example, these include the following: an | explicitly allow it. For example, these include the following: an | |||
Expires header (Section 15.3); a "max-age", "s-maxage", "must- | Expires header (Section 16.3); a "max-age", "s-maxage", "must- | |||
revalidate", "proxy-revalidate", "public" or "private" cache-control | revalidate", "proxy-revalidate", "public" or "private" cache-control | |||
directive (Section 15.2). | directive (Section 16.2). | |||
6. Constructing Responses From Caches | 7. Constructing Responses From Caches | |||
The purpose of an HTTP cache is to store information received in | The purpose of an HTTP cache is to store information received in | |||
response to requests for use in responding to future requests. In | response to requests for use in responding to future requests. In | |||
many cases, a cache simply returns the appropriate parts of a | many cases, a cache simply returns the appropriate parts of a | |||
response to the requester. However, if the cache holds a cache entry | response to the requester. However, if the cache holds a cache entry | |||
based on a previous response, it might have to combine parts of a new | based on a previous response, it might have to combine parts of a new | |||
response with what is held in the cache entry. | response with what is held in the cache entry. | |||
6.1. End-to-end and Hop-by-hop Headers | 7.1. End-to-end and Hop-by-hop Headers | |||
For the purpose of defining the behavior of caches and non-caching | For the purpose of defining the behavior of caches and non-caching | |||
proxies, we divide HTTP headers into two categories: | proxies, we divide HTTP headers into two categories: | |||
o End-to-end headers, which are transmitted to the ultimate | o End-to-end headers, which are transmitted to the ultimate | |||
recipient of a request or response. End-to-end headers in | recipient of a request or response. End-to-end headers in | |||
responses MUST be stored as part of a cache entry and MUST be | responses MUST be stored as part of a cache entry and MUST be | |||
transmitted in any response formed from a cache entry. | transmitted in any response formed from a cache entry. | |||
o Hop-by-hop headers, which are meaningful only for a single | o Hop-by-hop headers, which are meaningful only for a single | |||
skipping to change at page 20, line 37 | skipping to change at page 20, line 15 | |||
o Transfer-Encoding | o Transfer-Encoding | |||
o Upgrade | o Upgrade | |||
All other headers defined by HTTP/1.1 are end-to-end headers. | All other headers defined by HTTP/1.1 are end-to-end headers. | |||
Other hop-by-hop headers MUST be listed in a Connection header | Other hop-by-hop headers MUST be listed in a Connection header | |||
(Section 8.1 of [Part1]). | (Section 8.1 of [Part1]). | |||
6.2. Non-modifiable Headers | 7.2. Non-modifiable Headers | |||
Some features of the HTTP/1.1 protocol, such as Digest | Some features of HTTP/1.1, such as Digest Authentication, depend on | |||
Authentication, depend on the value of certain end-to-end headers. A | the value of certain end-to-end headers. A transparent proxy SHOULD | |||
transparent proxy SHOULD NOT modify an end-to-end header unless the | NOT modify an end-to-end header unless the definition of that header | |||
definition of that header requires or specifically allows that. | requires or specifically allows that. | |||
A transparent proxy MUST NOT modify any of the following fields in a | A transparent proxy MUST NOT modify any of the following fields in a | |||
request or response, and it MUST NOT add any of these fields if not | request or response, and it MUST NOT add any of these fields if not | |||
already present: | already present: | |||
o Content-Location | o Content-Location | |||
o Content-MD5 | o Content-MD5 | |||
o ETag | o ETag | |||
o Last-Modified | o Last-Modified | |||
A transparent proxy MUST NOT modify any of the following fields in a | A transparent proxy MUST NOT modify any of the following fields in a | |||
response: | response: | |||
o Expires | o Expires | |||
but it MAY add any of these fields if not already present. If an | but it MAY add any of these fields if not already present. If an | |||
skipping to change at page 21, line 24 | skipping to change at page 21, line 4 | |||
Expires header is added, it MUST be given a field-value identical to | Expires header is added, it MUST be given a field-value identical to | |||
that of the Date header in that response. | that of the Date header in that response. | |||
A proxy MUST NOT modify or add any of the following fields in a | A proxy MUST NOT modify or add any of the following fields in a | |||
message that contains the no-transform cache-control directive, or in | message that contains the no-transform cache-control directive, or in | |||
any request: | any request: | |||
o Content-Encoding | o Content-Encoding | |||
o Content-Range | o Content-Range | |||
o Content-Type | o Content-Type | |||
A non-transparent proxy MAY modify or add these fields to a message | A non-transparent proxy MAY modify or add these fields to a message | |||
that does not include no-transform, but if it does so, it MUST add a | that does not include no-transform, but if it does so, it MUST add a | |||
Warning 214 (Transformation applied) if one does not already appear | Warning 214 (Transformation applied) if one does not already appear | |||
in the message (see Section 15.6). | in the message (see Section 16.6). | |||
Warning: unnecessary modification of end-to-end headers might | Warning: unnecessary modification of end-to-end headers might | |||
cause authentication failures if stronger authentication | cause authentication failures if stronger authentication | |||
mechanisms are introduced in later versions of HTTP. Such | mechanisms are introduced in later versions of HTTP. Such | |||
authentication mechanisms MAY rely on the values of header fields | authentication mechanisms MAY rely on the values of header fields | |||
not listed here. | not listed here. | |||
The Content-Length field of a request or response is added or deleted | The Content-Length field of a request or response is added or deleted | |||
according to the rules in Section 4.4 of [Part1]. A transparent | according to the rules in Section 4.4 of [Part1]. A transparent | |||
proxy MUST preserve the entity-length (Section 3.2.2 of [Part3]) of | proxy MUST preserve the entity-length (Section 4.2.2 of [Part3]) of | |||
the entity-body, although it MAY change the transfer-length (Section | the entity-body, although it MAY change the transfer-length (Section | |||
4.4 of [Part1]). | 4.4 of [Part1]). | |||
6.3. Combining Headers | 7.3. Combining Headers | |||
When a cache makes a validating request to a server, and the server | When a cache makes a validating request to a server, and the server | |||
provides a 304 (Not Modified) response or a 206 (Partial Content) | provides a 304 (Not Modified) response or a 206 (Partial Content) | |||
response, the cache then constructs a response to send to the | response, the cache then constructs a response to send to the | |||
requesting client. | requesting client. | |||
If the status code is 304 (Not Modified), the cache uses the entity- | If the status code is 304 (Not Modified), the cache uses the entity- | |||
body stored in the cache entry as the entity-body of this outgoing | body stored in the cache entry as the entity-body of this outgoing | |||
response. If the status code is 206 (Partial Content) and the ETag | response. If the status code is 206 (Partial Content) and the ETag | |||
or Last-Modified headers match exactly, the cache MAY combine the | or Last-Modified headers match exactly, the cache MAY combine the | |||
contents stored in the cache entry with the new contents received in | contents stored in the cache entry with the new contents received in | |||
the response and use the result as the entity-body of this outgoing | the response and use the result as the entity-body of this outgoing | |||
response, (see Section 4 of [Part5]). | response, (see Section 5 of [Part5]). | |||
The end-to-end headers stored in the cache entry are used for the | The end-to-end headers stored in the cache entry are used for the | |||
constructed response, except that | constructed response, except that | |||
o any stored Warning headers with warn-code 1xx (see Section 15.6) | o any stored Warning headers with warn-code 1xx (see Section 16.6) | |||
MUST be deleted from the cache entry and the forwarded response. | MUST be deleted from the cache entry and the forwarded response. | |||
o any stored Warning headers with warn-code 2xx MUST be retained in | o any stored Warning headers with warn-code 2xx MUST be retained in | |||
the cache entry and the forwarded response. | the cache entry and the forwarded response. | |||
o any end-to-end headers provided in the 304 or 206 response MUST | o any end-to-end headers provided in the 304 or 206 response MUST | |||
replace the corresponding headers from the cache entry. | replace the corresponding headers from the cache entry. | |||
Unless the cache decides to remove the cache entry, it MUST also | Unless the cache decides to remove the cache entry, it MUST also | |||
replace the end-to-end headers stored with the cache entry with | replace the end-to-end headers stored with the cache entry with | |||
skipping to change at page 22, line 44 | skipping to change at page 22, line 23 | |||
Note: this rule allows an origin server to use a 304 (Not | Note: this rule allows an origin server to use a 304 (Not | |||
Modified) or a 206 (Partial Content) response to update any header | Modified) or a 206 (Partial Content) response to update any header | |||
associated with a previous response for the same entity or sub- | associated with a previous response for the same entity or sub- | |||
ranges thereof, although it might not always be meaningful or | ranges thereof, although it might not always be meaningful or | |||
correct to do so. This rule does not allow an origin server to | correct to do so. This rule does not allow an origin server to | |||
use a 304 (Not Modified) or a 206 (Partial Content) response to | use a 304 (Not Modified) or a 206 (Partial Content) response to | |||
entirely delete a header that it had provided with a previous | entirely delete a header that it had provided with a previous | |||
response. | response. | |||
7. Caching Negotiated Responses | 8. Caching Negotiated Responses | |||
Use of server-driven content negotiation (Section 4.1 of [Part3]), as | Use of server-driven content negotiation (Section 5.1 of [Part3]), as | |||
indicated by the presence of a Vary header field in a response, | indicated by the presence of a Vary header field in a response, | |||
alters the conditions and procedure by which a cache can use the | alters the conditions and procedure by which a cache can use the | |||
response for subsequent requests. See Section 15.5 for use of the | response for subsequent requests. See Section 16.5 for use of the | |||
Vary header field by servers. | Vary header field by servers. | |||
A server SHOULD use the Vary header field to inform a cache of what | A server SHOULD use the Vary header field to inform a cache of what | |||
request-header fields were used to select among multiple | request-header fields were used to select among multiple | |||
representations of a cacheable response subject to server-driven | representations of a cacheable response subject to server-driven | |||
negotiation. The set of header fields named by the Vary field value | negotiation. The set of header fields named by the Vary field value | |||
is known as the "selecting" request-headers. | is known as the "selecting" request-headers. | |||
When the cache receives a subsequent request whose Request-URI | When the cache receives a subsequent request whose Request-URI | |||
specifies one or more cache entries including a Vary header field, | specifies one or more cache entries including a Vary header field, | |||
skipping to change at page 24, line 12 | skipping to change at page 23, line 39 | |||
the If-None-Match header field unless the request is for a range that | the If-None-Match header field unless the request is for a range that | |||
would be fully satisfied by that entry. | would be fully satisfied by that entry. | |||
If a cache receives a successful response whose Content-Location | If a cache receives a successful response whose Content-Location | |||
field matches that of an existing cache entry for the same Request- | field matches that of an existing cache entry for the same Request- | |||
URI, whose entity-tag differs from that of the existing entry, and | URI, whose entity-tag differs from that of the existing entry, and | |||
whose Date is more recent than that of the existing entry, the | whose Date is more recent than that of the existing entry, the | |||
existing entry SHOULD NOT be returned in response to future requests | existing entry SHOULD NOT be returned in response to future requests | |||
and SHOULD be deleted from the cache. | and SHOULD be deleted from the cache. | |||
8. Shared and Non-Shared Caches | 9. Shared and Non-Shared Caches | |||
For reasons of security and privacy, it is necessary to make a | For reasons of security and privacy, it is necessary to make a | |||
distinction between "shared" and "non-shared" caches. A non-shared | distinction between "shared" and "non-shared" caches. A non-shared | |||
cache is one that is accessible only to a single user. Accessibility | cache is one that is accessible only to a single user. Accessibility | |||
in this case SHOULD be enforced by appropriate security mechanisms. | in this case SHOULD be enforced by appropriate security mechanisms. | |||
All other caches are considered to be "shared." Other sections of | All other caches are considered to be "shared." Other sections of | |||
this specification place certain constraints on the operation of | this specification place certain constraints on the operation of | |||
shared caches in order to prevent loss of privacy or failure of | shared caches in order to prevent loss of privacy or failure of | |||
access controls. | access controls. | |||
9. Errors or Incomplete Response Cache Behavior | 10. Errors or Incomplete Response Cache Behavior | |||
A cache that receives an incomplete response (for example, with fewer | A cache that receives an incomplete response (for example, with fewer | |||
bytes of data than specified in a Content-Length header) MAY store | bytes of data than specified in a Content-Length header) MAY store | |||
the response. However, the cache MUST treat this as a partial | the response. However, the cache MUST treat this as a partial | |||
response. Partial responses MAY be combined as described in Section | response. Partial responses MAY be combined as described in Section | |||
4 of [Part5]; the result might be a full response or might still be | 5 of [Part5]; the result might be a full response or might still be | |||
partial. A cache MUST NOT return a partial response to a client | partial. A cache MUST NOT return a partial response to a client | |||
without explicitly marking it as such, using the 206 (Partial | without explicitly marking it as such, using the 206 (Partial | |||
Content) status code. A cache MUST NOT return a partial response | Content) status code. A cache MUST NOT return a partial response | |||
using a status code of 200 (OK). | using a status code of 200 (OK). | |||
If a cache receives a 5xx response while attempting to revalidate an | If a cache receives a 5xx response while attempting to revalidate an | |||
entry, it MAY either forward this response to the requesting client, | entry, it MAY either forward this response to the requesting client, | |||
or act as if the server failed to respond. In the latter case, it | or act as if the server failed to respond. In the latter case, it | |||
MAY return a previously received response unless the cached entry | MAY return a previously received response unless the cached entry | |||
includes the "must-revalidate" cache-control directive (see | includes the "must-revalidate" cache-control directive (see | |||
Section 15.2). | Section 16.2). | |||
10. Side Effects of GET and HEAD | 11. Side Effects of GET and HEAD | |||
Unless the origin server explicitly prohibits the caching of their | Unless the origin server explicitly prohibits the caching of their | |||
responses, the application of GET and HEAD methods to any resources | responses, the application of GET and HEAD methods to any resources | |||
SHOULD NOT have side effects that would lead to erroneous behavior if | SHOULD NOT have side effects that would lead to erroneous behavior if | |||
these responses are taken from a cache. They MAY still have side | these responses are taken from a cache. They MAY still have side | |||
effects, but a cache is not required to consider such side effects in | effects, but a cache is not required to consider such side effects in | |||
its caching decisions. Caches are always expected to observe an | its caching decisions. Caches are always expected to observe an | |||
origin server's explicit restrictions on caching. | origin server's explicit restrictions on caching. | |||
We note one exception to this rule: since some applications have | We note one exception to this rule: since some applications have | |||
traditionally used GETs and HEADs with query URLs (those containing a | traditionally used GET and HEAD requests with URLs containing a query | |||
"?" in the rel_path part) to perform operations with significant side | part to perform operations with significant side effects, caches MUST | |||
effects, caches MUST NOT treat responses to such URIs as fresh unless | NOT treat responses to such URIs as fresh unless the server provides | |||
the server provides an explicit expiration time. This specifically | an explicit expiration time. This specifically means that responses | |||
means that responses from HTTP/1.0 servers for such URIs SHOULD NOT | from HTTP/1.0 servers for such URIs SHOULD NOT be taken from a cache. | |||
be taken from a cache. See Section 8.1.1 of [Part2] for related | See Section 8.1.1 of [Part2] for related information. | |||
information. | ||||
11. Invalidation After Updates or Deletions | 12. Invalidation After Updates or Deletions | |||
The effect of certain methods performed on a resource at the origin | The effect of certain methods performed on a resource at the origin | |||
server might cause one or more existing cache entries to become non- | server might cause one or more existing cache entries to become non- | |||
transparently invalid. That is, although they might continue to be | transparently invalid. That is, although they might continue to be | |||
"fresh," they do not accurately reflect what the origin server would | "fresh," they do not accurately reflect what the origin server would | |||
return for a new request on that resource. | return for a new request on that resource. | |||
There is no way for the HTTP protocol to guarantee that all such | There is no way for HTTP to guarantee that all such cache entries are | |||
cache entries are marked invalid. For example, the request that | marked invalid. For example, the request that caused the change at | |||
caused the change at the origin server might not have gone through | the origin server might not have gone through the proxy where a cache | |||
the proxy where a cache entry is stored. However, several rules help | entry is stored. However, several rules help reduce the likelihood | |||
reduce the likelihood of erroneous behavior. | of erroneous behavior. | |||
In this section, the phrase "invalidate an entity" means that the | In this section, the phrase "invalidate an entity" means that the | |||
cache will either remove all instances of that entity from its | cache will either remove all instances of that entity from its | |||
storage, or will mark these as "invalid" and in need of a mandatory | storage, or will mark these as "invalid" and in need of a mandatory | |||
revalidation before they can be returned in response to a subsequent | revalidation before they can be returned in response to a subsequent | |||
request. | request. | |||
Some HTTP methods MUST cause a cache to invalidate an entity. This | Some HTTP methods MUST cause a cache to invalidate an entity. This | |||
is either the entity referred to by the Request-URI, or by the | is either the entity referred to by the Request-URI, or by the | |||
Location or Content-Location headers (if present). These methods | Location or Content-Location headers (if present). These methods | |||
skipping to change at page 26, line 9 | skipping to change at page 25, line 35 | |||
An invalidation based on the URI in a Location or Content-Location | An invalidation based on the URI in a Location or Content-Location | |||
header MUST NOT be performed if the host part of that URI differs | header MUST NOT be performed if the host part of that URI differs | |||
from the host part in the Request-URI. This helps prevent denial of | from the host part in the Request-URI. This helps prevent denial of | |||
service attacks. | service attacks. | |||
A cache that passes through requests for methods it does not | A cache that passes through requests for methods it does not | |||
understand SHOULD invalidate any entities referred to by the Request- | understand SHOULD invalidate any entities referred to by the Request- | |||
URI. | URI. | |||
12. Write-Through Mandatory | 13. Write-Through Mandatory | |||
All methods that might be expected to cause modifications to the | All methods that might be expected to cause modifications to the | |||
origin server's resources MUST be written through to the origin | origin server's resources MUST be written through to the origin | |||
server. This currently includes all methods except for GET and HEAD. | server. This currently includes all methods except for GET and HEAD. | |||
A cache MUST NOT reply to such a request from a client before having | A cache MUST NOT reply to such a request from a client before having | |||
transmitted the request to the inbound server, and having received a | transmitted the request to the inbound server, and having received a | |||
corresponding response from the inbound server. This does not | corresponding response from the inbound server. This does not | |||
prevent a proxy cache from sending a 100 (Continue) response before | prevent a proxy cache from sending a 100 (Continue) response before | |||
the inbound server has sent its final reply. | the inbound server has sent its final reply. | |||
The alternative (known as "write-back" or "copy-back" caching) is not | The alternative (known as "write-back" or "copy-back" caching) is not | |||
allowed in HTTP/1.1, due to the difficulty of providing consistent | allowed in HTTP/1.1, due to the difficulty of providing consistent | |||
updates and the problems arising from server, cache, or network | updates and the problems arising from server, cache, or network | |||
failure prior to write-back. | failure prior to write-back. | |||
13. Cache Replacement | 14. Cache Replacement | |||
If a new cacheable (see Sections 15.2.2, 3.5, 3.6 and 9) response is | If a new cacheable (see Sections 16.2.2, 4.5, 4.6 and 10) response is | |||
received from a resource while any existing responses for the same | received from a resource while any existing responses for the same | |||
resource are cached, the cache SHOULD use the new response to reply | resource are cached, the cache SHOULD use the new response to reply | |||
to the current request. It MAY insert it into cache storage and MAY, | to the current request. It MAY insert it into cache storage and MAY, | |||
if it meets all other requirements, use it to respond to any future | if it meets all other requirements, use it to respond to any future | |||
requests that would previously have caused the old response to be | requests that would previously have caused the old response to be | |||
returned. If it inserts the new response into cache storage the | returned. If it inserts the new response into cache storage the | |||
rules in Section 6.3 apply. | rules in Section 7.3 apply. | |||
Note: a new response that has an older Date header value than | Note: a new response that has an older Date header value than | |||
existing cached responses is not cacheable. | existing cached responses is not cacheable. | |||
14. History Lists | 15. History Lists | |||
User agents often have history mechanisms, such as "Back" buttons and | User agents often have history mechanisms, such as "Back" buttons and | |||
history lists, which can be used to redisplay an entity retrieved | history lists, which can be used to redisplay an entity retrieved | |||
earlier in a session. | earlier in a session. | |||
History mechanisms and caches are different. In particular history | History mechanisms and caches are different. In particular history | |||
mechanisms SHOULD NOT try to show a semantically transparent view of | mechanisms SHOULD NOT try to show a semantically transparent view of | |||
the current state of a resource. Rather, a history mechanism is | the current state of a resource. Rather, a history mechanism is | |||
meant to show exactly what the user saw at the time when the resource | meant to show exactly what the user saw at the time when the resource | |||
was retrieved. | was retrieved. | |||
skipping to change at page 27, line 26 | skipping to change at page 27, line 5 | |||
they would otherwise like to. Service authors may consider it | they would otherwise like to. Service authors may consider it | |||
important that users not be presented with error messages or | important that users not be presented with error messages or | |||
warning messages when they use navigation controls (such as BACK) | warning messages when they use navigation controls (such as BACK) | |||
to view previously fetched resources. Even though sometimes such | to view previously fetched resources. Even though sometimes such | |||
resources ought not be cached, or ought to expire quickly, user | resources ought not be cached, or ought to expire quickly, user | |||
interface considerations may force service authors to resort to | interface considerations may force service authors to resort to | |||
other means of preventing caching (e.g. "once-only" URLs) in order | other means of preventing caching (e.g. "once-only" URLs) in order | |||
not to suffer the effects of improperly functioning history | not to suffer the effects of improperly functioning history | |||
mechanisms. | mechanisms. | |||
15. Header Field Definitions | 16. Header Field Definitions | |||
This section defines the syntax and semantics of HTTP/1.1 header | This section defines the syntax and semantics of HTTP/1.1 header | |||
fields related to caching. | fields related to caching. | |||
For entity-header fields, both sender and recipient refer to either | For entity-header fields, both sender and recipient refer to either | |||
the client or the server, depending on who sends and who receives the | the client or the server, depending on who sends and who receives the | |||
entity. | entity. | |||
15.1. Age | 16.1. Age | |||
The Age response-header field conveys the sender's estimate of the | The Age response-header field conveys the sender's estimate of the | |||
amount of time since the response (or its revalidation) was generated | amount of time since the response (or its revalidation) was generated | |||
at the origin server. A cached response is "fresh" if its age does | at the origin server. A cached response is "fresh" if its age does | |||
not exceed its freshness lifetime. Age values are calculated as | not exceed its freshness lifetime. Age values are calculated as | |||
specified in Section 3.3. | specified in Section 4.3. | |||
Age = "Age" ":" age-value | Age = "Age" ":" age-value | |||
age-value = delta-seconds | age-value = delta-seconds | |||
Age values are non-negative decimal integers, representing time in | Age values are non-negative decimal integers, representing time in | |||
seconds. | seconds. | |||
delta-seconds = 1*DIGIT | delta-seconds = 1*DIGIT | |||
If a cache receives a value larger than the largest positive integer | If a cache receives a value larger than the largest positive integer | |||
it can represent, or if any of its age calculations overflows, it | it can represent, or if any of its age calculations overflows, it | |||
MUST transmit an Age header with a value of 2147483648 (2^31). An | MUST transmit an Age header with a value of 2147483648 (2^31). An | |||
HTTP/1.1 server that includes a cache MUST include an Age header | HTTP/1.1 server that includes a cache MUST include an Age header | |||
field in every response generated from its own cache. Caches SHOULD | field in every response generated from its own cache. Caches SHOULD | |||
use an arithmetic type of at least 31 bits of range. | use an arithmetic type of at least 31 bits of range. | |||
15.2. Cache-Control | 16.2. Cache-Control | |||
The Cache-Control general-header field is used to specify directives | The Cache-Control general-header field is used to specify directives | |||
that MUST be obeyed by all caching mechanisms along the request/ | that MUST be obeyed by all caching mechanisms along the request/ | |||
response chain. The directives specify behavior intended to prevent | response chain. The directives specify behavior intended to prevent | |||
caches from adversely interfering with the request or response. | caches from adversely interfering with the request or response. | |||
These directives typically override the default caching algorithms. | These directives typically override the default caching algorithms. | |||
Cache directives are unidirectional in that the presence of a | Cache directives are unidirectional in that the presence of a | |||
directive in a request does not imply that the same directive is to | directive in a request does not imply that the same directive is to | |||
be given in the response. | be given in the response. | |||
Note that HTTP/1.0 caches might not implement Cache-Control and | Note that HTTP/1.0 caches might not implement Cache-Control and | |||
might only implement Pragma: no-cache (see Section 15.4). | might only implement Pragma: no-cache (see Section 16.4). | |||
Cache directives MUST be passed through by a proxy or gateway | Cache directives MUST be passed through by a proxy or gateway | |||
application, regardless of their significance to that application, | application, regardless of their significance to that application, | |||
since the directives might be applicable to all recipients along the | since the directives might be applicable to all recipients along the | |||
request/response chain. It is not possible to specify a cache- | request/response chain. It is not possible to specify a cache- | |||
directive for a specific cache. | directive for a specific cache. | |||
Cache-Control = "Cache-Control" ":" 1#cache-directive | Cache-Control = "Cache-Control" ":" 1#cache-directive | |||
cache-directive = cache-request-directive | cache-directive = cache-request-directive | |||
| cache-response-directive | | cache-response-directive | |||
cache-request-directive = | cache-request-directive = | |||
"no-cache" ; Section 15.2.1 | "no-cache" ; Section 16.2.1 | |||
| "no-store" ; Section 15.2.2 | | "no-store" ; Section 16.2.2 | |||
| "max-age" "=" delta-seconds ; Section 15.2.3, 15.2.4 | | "max-age" "=" delta-seconds ; Section 16.2.3, 16.2.4 | |||
| "max-stale" [ "=" delta-seconds ] ; Section 15.2.3 | | "max-stale" [ "=" delta-seconds ] ; Section 16.2.3 | |||
| "min-fresh" "=" delta-seconds ; Section 15.2.3 | | "min-fresh" "=" delta-seconds ; Section 16.2.3 | |||
| "no-transform" ; Section 15.2.5 | | "no-transform" ; Section 16.2.5 | |||
| "only-if-cached" ; Section 15.2.4 | | "only-if-cached" ; Section 16.2.4 | |||
| cache-extension ; Section 15.2.6 | | cache-extension ; Section 16.2.6 | |||
cache-response-directive = | cache-response-directive = | |||
"public" ; Section 15.2.1 | "public" ; Section 16.2.1 | |||
| "private" [ "=" DQUOTE 1#field-name DQUOTE ] ; Section 15.2.1 | | "private" [ "=" DQUOTE 1#field-name DQUOTE ] ; Section 16.2.1 | |||
| "no-cache" [ "=" DQUOTE 1#field-name DQUOTE ]; Section 15.2.1 | | "no-cache" [ "=" DQUOTE 1#field-name DQUOTE ] ; Section 16.2.1 | |||
| "no-store" ; Section 15.2.2 | | "no-store" ; Section 16.2.2 | |||
| "no-transform" ; Section 15.2.5 | | "no-transform" ; Section 16.2.5 | |||
| "must-revalidate" ; Section 15.2.4 | | "must-revalidate" ; Section 16.2.4 | |||
| "proxy-revalidate" ; Section 15.2.4 | | "proxy-revalidate" ; Section 16.2.4 | |||
| "max-age" "=" delta-seconds ; Section 15.2.3 | | "max-age" "=" delta-seconds ; Section 16.2.3 | |||
| "s-maxage" "=" delta-seconds ; Section 15.2.3 | | "s-maxage" "=" delta-seconds ; Section 16.2.3 | |||
| cache-extension ; Section 15.2.6 | | cache-extension ; Section 16.2.6 | |||
cache-extension = token [ "=" ( token | quoted-string ) ] | cache-extension = token [ "=" ( token | quoted-string ) ] | |||
When a directive appears without any 1#field-name parameter, the | When a directive appears without any 1#field-name parameter, the | |||
directive applies to the entire request or response. When such a | directive applies to the entire request or response. When such a | |||
directive appears with a 1#field-name parameter, it applies only to | directive appears with a 1#field-name parameter, it applies only to | |||
the named field or fields, and not to the rest of the request or | the named field or fields, and not to the rest of the request or | |||
response. This mechanism supports extensibility; implementations of | response. This mechanism supports extensibility; implementations of | |||
future versions of the HTTP protocol might apply these directives to | future versions of HTTP might apply these directives to header fields | |||
header fields not defined in HTTP/1.1. | not defined in HTTP/1.1. | |||
The cache-control directives can be broken down into these general | The cache-control directives can be broken down into these general | |||
categories: | categories: | |||
o Restrictions on what are cacheable; these may only be imposed by | o Restrictions on what are cacheable; these may only be imposed by | |||
the origin server. | the origin server. | |||
o Restrictions on what may be stored by a cache; these may be | o Restrictions on what may be stored by a cache; these may be | |||
imposed by either the origin server or the user agent. | imposed by either the origin server or the user agent. | |||
o Modifications of the basic expiration mechanism; these may be | o Modifications of the basic expiration mechanism; these may be | |||
imposed by either the origin server or the user agent. | imposed by either the origin server or the user agent. | |||
o Controls over cache revalidation and reload; these may only be | o Controls over cache revalidation and reload; these may only be | |||
imposed by a user agent. | imposed by a user agent. | |||
o Control over transformation of entities. | o Control over transformation of entities. | |||
o Extensions to the caching system. | o Extensions to the caching system. | |||
15.2.1. What is Cacheable | 16.2.1. What is Cacheable | |||
By default, a response is cacheable if the requirements of the | By default, a response is cacheable if the requirements of the | |||
request method, request header fields, and the response status | request method, request header fields, and the response status | |||
indicate that it is cacheable. Section 5 summarizes these defaults | indicate that it is cacheable. Section 6 summarizes these defaults | |||
for cacheability. The following Cache-Control response directives | for cacheability. The following Cache-Control response directives | |||
allow an origin server to override the default cacheability of a | allow an origin server to override the default cacheability of a | |||
response: | response: | |||
public | public | |||
Indicates that the response MAY be cached by any cache, even if it | Indicates that the response MAY be cached by any cache, even if it | |||
would normally be non-cacheable or cacheable only within a non- | would normally be non-cacheable or cacheable only within a non- | |||
shared cache. (See also Authorization, Section 3.1 of [Part7], | shared cache. (See also Authorization, Section 4.1 of [Part7], | |||
for additional details.) | for additional details.) | |||
private | private | |||
Indicates that all or part of the response message is intended for | Indicates that all or part of the response message is intended for | |||
a single user and MUST NOT be cached by a shared cache. This | a single user and MUST NOT be cached by a shared cache. This | |||
allows an origin server to state that the specified parts of the | allows an origin server to state that the specified parts of the | |||
response are intended for only one user and are not a valid | response are intended for only one user and are not a valid | |||
response for requests by other users. A private (non-shared) | response for requests by other users. A private (non-shared) | |||
cache MAY cache the response. | cache MAY cache the response. | |||
skipping to change at page 31, line 12 | skipping to change at page 30, line 18 | |||
subject to any other restrictions on caching. However, the | subject to any other restrictions on caching. However, the | |||
specified field-name(s) MUST NOT be sent in the response to a | specified field-name(s) MUST NOT be sent in the response to a | |||
subsequent request without successful revalidation with the origin | subsequent request without successful revalidation with the origin | |||
server. This allows an origin server to prevent the re-use of | server. This allows an origin server to prevent the re-use of | |||
certain header fields in a response, while still allowing caching | certain header fields in a response, while still allowing caching | |||
of the rest of the response. | of the rest of the response. | |||
Note: Most HTTP/1.0 caches will not recognize or obey this | Note: Most HTTP/1.0 caches will not recognize or obey this | |||
directive. | directive. | |||
15.2.2. What May be Stored by Caches | 16.2.2. What May be Stored by Caches | |||
no-store | no-store | |||
The purpose of the no-store directive is to prevent the | The purpose of the no-store directive is to prevent the | |||
inadvertent release or retention of sensitive information (for | inadvertent release or retention of sensitive information (for | |||
example, on backup tapes). The no-store directive applies to the | example, on backup tapes). The no-store directive applies to the | |||
entire message, and MAY be sent either in a response or in a | entire message, and MAY be sent either in a response or in a | |||
request. If sent in a request, a cache MUST NOT store any part of | request. If sent in a request, a cache MUST NOT store any part of | |||
either this request or any response to it. If sent in a response, | either this request or any response to it. If sent in a response, | |||
a cache MUST NOT store any part of either this response or the | a cache MUST NOT store any part of either this response or the | |||
skipping to change at page 31, line 45 | skipping to change at page 31, line 5 | |||
The purpose of this directive is to meet the stated requirements | The purpose of this directive is to meet the stated requirements | |||
of certain users and service authors who are concerned about | of certain users and service authors who are concerned about | |||
accidental releases of information via unanticipated accesses to | accidental releases of information via unanticipated accesses to | |||
cache data structures. While the use of this directive might | cache data structures. While the use of this directive might | |||
improve privacy in some cases, we caution that it is NOT in any | improve privacy in some cases, we caution that it is NOT in any | |||
way a reliable or sufficient mechanism for ensuring privacy. In | way a reliable or sufficient mechanism for ensuring privacy. In | |||
particular, malicious or compromised caches might not recognize or | particular, malicious or compromised caches might not recognize or | |||
obey this directive, and communications networks might be | obey this directive, and communications networks might be | |||
vulnerable to eavesdropping. | vulnerable to eavesdropping. | |||
15.2.3. Modifications of the Basic Expiration Mechanism | 16.2.3. Modifications of the Basic Expiration Mechanism | |||
The expiration time of an entity MAY be specified by the origin | The expiration time of an entity MAY be specified by the origin | |||
server using the Expires header (see Section 15.3). Alternatively, | server using the Expires header (see Section 16.3). Alternatively, | |||
it MAY be specified using the max-age directive in a response. When | it MAY be specified using the max-age directive in a response. When | |||
the max-age cache-control directive is present in a cached response, | the max-age cache-control directive is present in a cached response, | |||
the response is stale if its current age is greater than the age | the response is stale if its current age is greater than the age | |||
value given (in seconds) at the time of a new request for that | value given (in seconds) at the time of a new request for that | |||
resource. The max-age directive on a response implies that the | resource. The max-age directive on a response implies that the | |||
response is cacheable (i.e., "public") unless some other, more | response is cacheable (i.e., "public") unless some other, more | |||
restrictive cache directive is also present. | restrictive cache directive is also present. | |||
If a response includes both an Expires header and a max-age | If a response includes both an Expires header and a max-age | |||
directive, the max-age directive overrides the Expires header, even | directive, the max-age directive overrides the Expires header, even | |||
skipping to change at page 32, line 39 | skipping to change at page 31, line 47 | |||
Date value. This will prevent older caches from improperly | Date value. This will prevent older caches from improperly | |||
caching the response. | caching the response. | |||
s-maxage | s-maxage | |||
If a response includes an s-maxage directive, then for a shared | If a response includes an s-maxage directive, then for a shared | |||
cache (but not for a private cache), the maximum age specified by | cache (but not for a private cache), the maximum age specified by | |||
this directive overrides the maximum age specified by either the | this directive overrides the maximum age specified by either the | |||
max-age directive or the Expires header. The s-maxage directive | max-age directive or the Expires header. The s-maxage directive | |||
also implies the semantics of the proxy-revalidate directive (see | also implies the semantics of the proxy-revalidate directive (see | |||
Section 15.2.4), i.e., that the shared cache must not use the | Section 16.2.4), i.e., that the shared cache must not use the | |||
entry after it becomes stale to respond to a subsequent request | entry after it becomes stale to respond to a subsequent request | |||
without first revalidating it with the origin server. The | without first revalidating it with the origin server. The | |||
s-maxage directive is always ignored by a private cache. | s-maxage directive is always ignored by a private cache. | |||
Note that most older caches, not compliant with this specification, | Note that most older caches, not compliant with this specification, | |||
do not implement any cache-control directives. An origin server | do not implement any cache-control directives. An origin server | |||
wishing to use a cache-control directive that restricts, but does not | wishing to use a cache-control directive that restricts, but does not | |||
prevent, caching by an HTTP/1.1-compliant cache MAY exploit the | prevent, caching by an HTTP/1.1-compliant cache MAY exploit the | |||
requirement that the max-age directive overrides the Expires header, | requirement that the max-age directive overrides the Expires header, | |||
and the fact that pre-HTTP/1.1-compliant caches do not observe the | and the fact that pre-HTTP/1.1-compliant caches do not observe the | |||
skipping to change at page 33, line 47 | skipping to change at page 33, line 5 | |||
A cache MAY be configured to return stale responses without | A cache MAY be configured to return stale responses without | |||
validation, but only if this does not conflict with any "MUST"-level | validation, but only if this does not conflict with any "MUST"-level | |||
requirements concerning cache validation (e.g., a "must-revalidate" | requirements concerning cache validation (e.g., a "must-revalidate" | |||
cache-control directive). | cache-control directive). | |||
If both the new request and the cached entry include "max-age" | If both the new request and the cached entry include "max-age" | |||
directives, then the lesser of the two values is used for determining | directives, then the lesser of the two values is used for determining | |||
the freshness of the cached entry for that request. | the freshness of the cached entry for that request. | |||
15.2.4. Cache Revalidation and Reload Controls | 16.2.4. Cache Revalidation and Reload Controls | |||
Sometimes a user agent might want or need to insist that a cache | Sometimes a user agent might want or need to insist that a cache | |||
revalidate its cache entry with the origin server (and not just with | revalidate its cache entry with the origin server (and not just with | |||
the next cache along the path to the origin server), or to reload its | the next cache along the path to the origin server), or to reload its | |||
cache entry from the origin server. End-to-end revalidation might be | cache entry from the origin server. End-to-end revalidation might be | |||
necessary if either the cache or the origin server has overestimated | necessary if either the cache or the origin server has overestimated | |||
the expiration time of the cached response. End-to-end reload may be | the expiration time of the cached response. End-to-end reload may be | |||
necessary if the cache entry has become corrupted for some reason. | necessary if the cache entry has become corrupted for some reason. | |||
End-to-end revalidation may be requested either when the client does | End-to-end revalidation may be requested either when the client does | |||
skipping to change at page 36, line 31 | skipping to change at page 35, line 38 | |||
revalidate directive, except that it does not apply to non-shared | revalidate directive, except that it does not apply to non-shared | |||
user agent caches. It can be used on a response to an | user agent caches. It can be used on a response to an | |||
authenticated request to permit the user's cache to store and | authenticated request to permit the user's cache to store and | |||
later return the response without needing to revalidate it (since | later return the response without needing to revalidate it (since | |||
it has already been authenticated once by that user), while still | it has already been authenticated once by that user), while still | |||
requiring proxies that service many users to revalidate each time | requiring proxies that service many users to revalidate each time | |||
(in order to make sure that each user has been authenticated). | (in order to make sure that each user has been authenticated). | |||
Note that such authenticated responses also need the public cache | Note that such authenticated responses also need the public cache | |||
control directive in order to allow them to be cached at all. | control directive in order to allow them to be cached at all. | |||
15.2.5. No-Transform Directive | 16.2.5. No-Transform Directive | |||
no-transform | no-transform | |||
Implementors of intermediate caches (proxies) have found it useful | Implementors of intermediate caches (proxies) have found it useful | |||
to convert the media type of certain entity bodies. A non- | to convert the media type of certain entity bodies. A non- | |||
transparent proxy might, for example, convert between image | transparent proxy might, for example, convert between image | |||
formats in order to save cache space or to reduce the amount of | formats in order to save cache space or to reduce the amount of | |||
traffic on a slow link. | traffic on a slow link. | |||
Serious operational problems occur, however, when these | Serious operational problems occur, however, when these | |||
transformations are applied to entity bodies intended for certain | transformations are applied to entity bodies intended for certain | |||
kinds of applications. For example, applications for medical | kinds of applications. For example, applications for medical | |||
imaging, scientific data analysis and those using end-to-end | imaging, scientific data analysis and those using end-to-end | |||
authentication, all depend on receiving an entity body that is bit | authentication, all depend on receiving an entity body that is bit | |||
for bit identical to the original entity-body. | for bit identical to the original entity-body. | |||
Therefore, if a message includes the no-transform directive, an | Therefore, if a message includes the no-transform directive, an | |||
intermediate cache or proxy MUST NOT change those headers that are | intermediate cache or proxy MUST NOT change those headers that are | |||
listed in Section 6.2 as being subject to the no-transform | listed in Section 7.2 as being subject to the no-transform | |||
directive. This implies that the cache or proxy MUST NOT change | directive. This implies that the cache or proxy MUST NOT change | |||
any aspect of the entity-body that is specified by these headers, | any aspect of the entity-body that is specified by these headers, | |||
including the value of the entity-body itself. | including the value of the entity-body itself. | |||
15.2.6. Cache Control Extensions | 16.2.6. Cache Control Extensions | |||
The Cache-Control header field can be extended through the use of one | The Cache-Control header field can be extended through the use of one | |||
or more cache-extension tokens, each with an optional assigned value. | or more cache-extension tokens, each with an optional assigned value. | |||
Informational extensions (those which do not require a change in | Informational extensions (those which do not require a change in | |||
cache behavior) MAY be added without changing the semantics of other | cache behavior) MAY be added without changing the semantics of other | |||
directives. Behavioral extensions are designed to work by acting as | directives. Behavioral extensions are designed to work by acting as | |||
modifiers to the existing base of cache directives. Both the new | modifiers to the existing base of cache directives. Both the new | |||
directive and the standard directive are supplied, such that | directive and the standard directive are supplied, such that | |||
applications which do not understand the new directive will default | applications which do not understand the new directive will default | |||
to the behavior specified by the standard directive, and those that | to the behavior specified by the standard directive, and those that | |||
skipping to change at page 37, line 48 | skipping to change at page 37, line 8 | |||
does not understand the community cache-extension, since it will also | does not understand the community cache-extension, since it will also | |||
see and understand the private directive and thus default to the safe | see and understand the private directive and thus default to the safe | |||
behavior. | behavior. | |||
Unrecognized cache-directives MUST be ignored; it is assumed that any | Unrecognized cache-directives MUST be ignored; it is assumed that any | |||
cache-directive likely to be unrecognized by an HTTP/1.1 cache will | cache-directive likely to be unrecognized by an HTTP/1.1 cache will | |||
be combined with standard directives (or the response's default | be combined with standard directives (or the response's default | |||
cacheability) such that the cache behavior will remain minimally | cacheability) such that the cache behavior will remain minimally | |||
correct even if the cache does not understand the extension(s). | correct even if the cache does not understand the extension(s). | |||
15.3. Expires | 16.3. Expires | |||
The Expires entity-header field gives the date/time after which the | The Expires entity-header field gives the date/time after which the | |||
response is considered stale. A stale cache entry may not normally | response is considered stale. A stale cache entry may not normally | |||
be returned by a cache (either a proxy cache or a user agent cache) | be returned by a cache (either a proxy cache or a user agent cache) | |||
unless it is first validated with the origin server (or with an | unless it is first validated with the origin server (or with an | |||
intermediate cache that has a fresh copy of the entity). See | intermediate cache that has a fresh copy of the entity). See | |||
Section 3 for further discussion of the expiration model. | Section 4 for further discussion of the expiration model. | |||
The presence of an Expires field does not imply that the original | The presence of an Expires field does not imply that the original | |||
resource will change or cease to exist at, before, or after that | resource will change or cease to exist at, before, or after that | |||
time. | time. | |||
The format is an absolute date and time as defined by HTTP-date in | The format is an absolute date and time as defined by HTTP-date in | |||
Section 3.3.1 of [Part1]; it MUST be sent in rfc1123-date format. | Section 3.3.1 of [Part1]; it MUST be sent in rfc1123-date format. | |||
Expires = "Expires" ":" HTTP-date | Expires = "Expires" ":" HTTP-date | |||
An example of its use is | An example of its use is | |||
Expires: Thu, 01 Dec 1994 16:00:00 GMT | Expires: Thu, 01 Dec 1994 16:00:00 GMT | |||
Note: if a response includes a Cache-Control field with the max- | Note: if a response includes a Cache-Control field with the max- | |||
age directive (see Section 15.2.3), that directive overrides the | age directive (see Section 16.2.3), that directive overrides the | |||
Expires field. | Expires field. | |||
HTTP/1.1 clients and caches MUST treat other invalid date formats, | HTTP/1.1 clients and caches MUST treat other invalid date formats, | |||
especially including the value "0", as in the past (i.e., "already | especially including the value "0", as in the past (i.e., "already | |||
expired"). | expired"). | |||
To mark a response as "already expired," an origin server sends an | To mark a response as "already expired," an origin server sends an | |||
Expires date that is equal to the Date header value. (See the rules | Expires date that is equal to the Date header value. (See the rules | |||
for expiration calculations in Section 3.4.) | for expiration calculations in Section 4.4.) | |||
To mark a response as "never expires," an origin server sends an | To mark a response as "never expires," an origin server sends an | |||
Expires date approximately one year from the time the response is | Expires date approximately one year from the time the response is | |||
sent. HTTP/1.1 servers SHOULD NOT send Expires dates more than one | sent. HTTP/1.1 servers SHOULD NOT send Expires dates more than one | |||
year in the future. | year in the future. | |||
The presence of an Expires header field with a date value of some | The presence of an Expires header field with a date value of some | |||
time in the future on a response that otherwise would by default be | time in the future on a response that otherwise would by default be | |||
non-cacheable indicates that the response is cacheable, unless | non-cacheable indicates that the response is cacheable, unless | |||
indicated otherwise by a Cache-Control header field (Section 15.2). | indicated otherwise by a Cache-Control header field (Section 16.2). | |||
15.4. Pragma | 16.4. Pragma | |||
The Pragma general-header field is used to include implementation- | The Pragma general-header field is used to include implementation- | |||
specific directives that might apply to any recipient along the | specific directives that might apply to any recipient along the | |||
request/response chain. All pragma directives specify optional | request/response chain. All pragma directives specify optional | |||
behavior from the viewpoint of the protocol; however, some systems | behavior from the viewpoint of the protocol; however, some systems | |||
MAY require that behavior be consistent with the directives. | MAY require that behavior be consistent with the directives. | |||
Pragma = "Pragma" ":" 1#pragma-directive | Pragma = "Pragma" ":" 1#pragma-directive | |||
pragma-directive = "no-cache" | extension-pragma | pragma-directive = "no-cache" | extension-pragma | |||
extension-pragma = token [ "=" ( token | quoted-string ) ] | extension-pragma = token [ "=" ( token | quoted-string ) ] | |||
When the no-cache directive is present in a request message, an | When the no-cache directive is present in a request message, an | |||
application SHOULD forward the request toward the origin server even | application SHOULD forward the request toward the origin server even | |||
if it has a cached copy of what is being requested. This pragma | if it has a cached copy of what is being requested. This pragma | |||
directive has the same semantics as the no-cache cache-directive (see | directive has the same semantics as the no-cache cache-directive (see | |||
Section 15.2) and is defined here for backward compatibility with | Section 16.2) and is defined here for backward compatibility with | |||
HTTP/1.0. Clients SHOULD include both header fields when a no-cache | HTTP/1.0. Clients SHOULD include both header fields when a no-cache | |||
request is sent to a server not known to be HTTP/1.1 compliant. | request is sent to a server not known to be HTTP/1.1 compliant. | |||
Pragma directives MUST be passed through by a proxy or gateway | Pragma directives MUST be passed through by a proxy or gateway | |||
application, regardless of their significance to that application, | application, regardless of their significance to that application, | |||
since the directives might be applicable to all recipients along the | since the directives might be applicable to all recipients along the | |||
request/response chain. It is not possible to specify a pragma for a | request/response chain. It is not possible to specify a pragma for a | |||
specific recipient; however, any pragma directive not relevant to a | specific recipient; however, any pragma directive not relevant to a | |||
recipient SHOULD be ignored by that recipient. | recipient SHOULD be ignored by that recipient. | |||
HTTP/1.1 caches SHOULD treat "Pragma: no-cache" as if the client had | HTTP/1.1 caches SHOULD treat "Pragma: no-cache" as if the client had | |||
sent "Cache-Control: no-cache". No new Pragma directives will be | sent "Cache-Control: no-cache". No new Pragma directives will be | |||
defined in HTTP. | defined in HTTP. | |||
Note: because the meaning of "Pragma: no-cache" as a response- | Note: because the meaning of "Pragma: no-cache" as a response- | |||
header field is not actually specified, it does not provide a | header field is not actually specified, it does not provide a | |||
reliable replacement for "Cache-Control: no-cache" in a response. | reliable replacement for "Cache-Control: no-cache" in a response. | |||
15.5. Vary | 16.5. Vary | |||
The Vary field value indicates the set of request-header fields that | The Vary field value indicates the set of request-header fields that | |||
fully determines, while the response is fresh, whether a cache is | fully determines, while the response is fresh, whether a cache is | |||
permitted to use the response to reply to a subsequent request | permitted to use the response to reply to a subsequent request | |||
without revalidation. For uncacheable or stale responses, the Vary | without revalidation. For uncacheable or stale responses, the Vary | |||
field value advises the user agent about the criteria that were used | field value advises the user agent about the criteria that were used | |||
to select the representation. A Vary field value of "*" implies that | to select the representation. A Vary field value of "*" implies that | |||
a cache cannot determine from the request headers of a subsequent | a cache cannot determine from the request headers of a subsequent | |||
request whether this response is the appropriate representation. See | request whether this response is the appropriate representation. See | |||
Section 7 for use of the Vary header field by caches. | Section 8 for use of the Vary header field by caches. | |||
Vary = "Vary" ":" ( "*" | 1#field-name ) | Vary = "Vary" ":" ( "*" | 1#field-name ) | |||
An HTTP/1.1 server SHOULD include a Vary header field with any | An HTTP/1.1 server SHOULD include a Vary header field with any | |||
cacheable response that is subject to server-driven negotiation. | cacheable response that is subject to server-driven negotiation. | |||
Doing so allows a cache to properly interpret future requests on that | Doing so allows a cache to properly interpret future requests on that | |||
resource and informs the user agent about the presence of negotiation | resource and informs the user agent about the presence of negotiation | |||
on that resource. A server MAY include a Vary header field with a | on that resource. A server MAY include a Vary header field with a | |||
non-cacheable response that is subject to server-driven negotiation, | non-cacheable response that is subject to server-driven negotiation, | |||
since this might provide the user agent with useful information about | since this might provide the user agent with useful information about | |||
the dimensions over which the response varies at the time of the | the dimensions over which the response varies at the time of the | |||
response. | response. | |||
skipping to change at page 40, line 25 | skipping to change at page 39, line 32 | |||
The field-names given are not limited to the set of standard request- | The field-names given are not limited to the set of standard request- | |||
header fields defined by this specification. Field names are case- | header fields defined by this specification. Field names are case- | |||
insensitive. | insensitive. | |||
A Vary field value of "*" signals that unspecified parameters not | A Vary field value of "*" signals that unspecified parameters not | |||
limited to the request-headers (e.g., the network address of the | limited to the request-headers (e.g., the network address of the | |||
client), play a role in the selection of the response representation. | client), play a role in the selection of the response representation. | |||
The "*" value MUST NOT be generated by a proxy server; it may only be | The "*" value MUST NOT be generated by a proxy server; it may only be | |||
generated by an origin server. | generated by an origin server. | |||
15.6. Warning | 16.6. Warning | |||
The Warning general-header field is used to carry additional | The Warning general-header field is used to carry additional | |||
information about the status or transformation of a message which | information about the status or transformation of a message which | |||
might not be reflected in the message. This information is typically | might not be reflected in the message. This information is typically | |||
used to warn about a possible lack of semantic transparency from | used to warn about a possible lack of semantic transparency from | |||
caching operations or transformations applied to the entity body of | caching operations or transformations applied to the entity body of | |||
the message. | the message. | |||
Warning headers are sent with responses using: | Warning headers are sent with responses using: | |||
Warning = "Warning" ":" 1#warning-value | Warning = "Warning" ":" 1#warning-value | |||
warning-value = warn-code SP warn-agent SP warn-text | warning-value = warn-code SP warn-agent SP warn-text | |||
[SP warn-date] | [SP warn-date] | |||
warn-code = 3DIGIT | warn-code = 3DIGIT | |||
warn-agent = ( host [ ":" port ] ) | pseudonym | warn-agent = ( uri-host [ ":" port ] ) | pseudonym | |||
; the name or pseudonym of the server adding | ; the name or pseudonym of the server adding | |||
; the Warning header, for use in debugging | ; the Warning header, for use in debugging | |||
warn-text = quoted-string | warn-text = quoted-string | |||
warn-date = DQUOTE HTTP-date DQUOTE | warn-date = DQUOTE HTTP-date DQUOTE | |||
A response MAY carry more than one Warning header. | A response MAY carry more than one Warning header. | |||
The warn-text SHOULD be in a natural language and character set that | The warn-text SHOULD be in a natural language and character set that | |||
is most likely to be intelligible to the human user receiving the | is most likely to be intelligible to the human user receiving the | |||
response. This decision MAY be based on any available knowledge, | response. This decision MAY be based on any available knowledge, | |||
skipping to change at page 41, line 42 | skipping to change at page 41, line 10 | |||
those appearing later in the response. | those appearing later in the response. | |||
o Warnings in the user's preferred character set take priority over | o Warnings in the user's preferred character set take priority over | |||
warnings in other character sets but with identical warn-codes and | warnings in other character sets but with identical warn-codes and | |||
warn-agents. | warn-agents. | |||
Systems that generate multiple Warning headers SHOULD order them with | Systems that generate multiple Warning headers SHOULD order them with | |||
this user agent behavior in mind. | this user agent behavior in mind. | |||
Requirements for the behavior of caches with respect to Warnings are | Requirements for the behavior of caches with respect to Warnings are | |||
stated in Section 2.2. | stated in Section 3.2. | |||
This is a list of the currently-defined warn-codes, each with a | This is a list of the currently-defined warn-codes, each with a | |||
recommended warn-text in English, and a description of its meaning. | recommended warn-text in English, and a description of its meaning. | |||
110 Response is stale | 110 Response is stale | |||
MUST be included whenever the returned response is stale. | MUST be included whenever the returned response is stale. | |||
111 Revalidation failed | 111 Revalidation failed | |||
MUST be included if a cache returns a stale response because an | MUST be included if a cache returns a stale response because an | |||
attempt to revalidate the response failed, due to an inability to | attempt to revalidate the response failed, due to an inability to | |||
reach the server. | reach the server. | |||
112 Disconnected operation | 112 Disconnected operation | |||
SHOULD be included if the cache is intentionally disconnected from | SHOULD be included if the cache is intentionally disconnected from | |||
the rest of the network for a period of time. | the rest of the network for a period of time. | |||
113 Heuristic expiration | 113 Heuristic expiration | |||
skipping to change at page 43, line 5 | skipping to change at page 42, line 23 | |||
each warning-value a warn-date that matches the date in the response. | each warning-value a warn-date that matches the date in the response. | |||
If an implementation receives a message with a warning-value that | If an implementation receives a message with a warning-value that | |||
includes a warn-date, and that warn-date is different from the Date | includes a warn-date, and that warn-date is different from the Date | |||
value in the response, then that warning-value MUST be deleted from | value in the response, then that warning-value MUST be deleted from | |||
the message before storing, forwarding, or using it. (This prevents | the message before storing, forwarding, or using it. (This prevents | |||
bad consequences of naive caching of Warning header fields.) If all | bad consequences of naive caching of Warning header fields.) If all | |||
of the warning-values are deleted for this reason, the Warning header | of the warning-values are deleted for this reason, the Warning header | |||
MUST be deleted as well. | MUST be deleted as well. | |||
16. IANA Considerations | 17. IANA Considerations | |||
TBD. | [[anchor1: TBD.]] | |||
17. Security Considerations | 18. Security Considerations | |||
Caching proxies provide additional potential vulnerabilities, since | Caching proxies provide additional potential vulnerabilities, since | |||
the contents of the cache represent an attractive target for | the contents of the cache represent an attractive target for | |||
malicious exploitation. Because cache contents persist after an HTTP | malicious exploitation. Because cache contents persist after an HTTP | |||
request is complete, an attack on the cache can reveal information | request is complete, an attack on the cache can reveal information | |||
long after a user believes that the information has been removed from | long after a user believes that the information has been removed from | |||
the network. Therefore, cache contents should be protected as | the network. Therefore, cache contents should be protected as | |||
sensitive information. | sensitive information. | |||
18. Acknowledgments | 19. Acknowledgments | |||
Much of the content and presentation of the caching design is due to | Much of the content and presentation of the caching design is due to | |||
suggestions and comments from individuals including: Shel Kaphan, | suggestions and comments from individuals including: Shel Kaphan, | |||
Paul Leach, Koen Holtman, David Morris, and Larry Masinter. | Paul Leach, Koen Holtman, David Morris, and Larry Masinter. | |||
19. References | 20. References | |||
19.1. Normative References | 20.1. Normative References | |||
[ISO-8859-1] | [ISO-8859-1] | |||
International Organization for Standardization, | International Organization for Standardization, | |||
"Information technology -- 8-bit single-byte coded graphic | "Information technology -- 8-bit single-byte coded graphic | |||
character sets -- Part 1: Latin alphabet No. 1", ISO/ | character sets -- Part 1: Latin alphabet No. 1", ISO/ | |||
IEC 8859-1:1998, 1998. | IEC 8859-1:1998, 1998. | |||
[Part1] Fielding, R., Ed., Gettys, J., Mogul, J., Frystyk, H., | [Part1] Fielding, R., Ed., Gettys, J., Mogul, J., Frystyk, H., | |||
Masinter, L., Leach, P., Berners-Lee, T., Lafon, Y., Ed., | Masinter, L., Leach, P., Berners-Lee, T., Lafon, Y., Ed., | |||
and J. Reschke, Ed., "HTTP/1.1, part 1: URIs, Connections, | and J. Reschke, Ed., "HTTP/1.1, part 1: URIs, Connections, | |||
and Message Parsing", draft-ietf-httpbis-p1-messaging-01 | and Message Parsing", draft-ietf-httpbis-p1-messaging-02 | |||
(work in progress), January 2008. | (work in progress), February 2008. | |||
[Part2] Fielding, R., Ed., Gettys, J., Mogul, J., Frystyk, H., | [Part2] Fielding, R., Ed., Gettys, J., Mogul, J., Frystyk, H., | |||
Masinter, L., Leach, P., Berners-Lee, T., Lafon, Y., Ed., | Masinter, L., Leach, P., Berners-Lee, T., Lafon, Y., Ed., | |||
and J. Reschke, Ed., "HTTP/1.1, part 2: Message | and J. Reschke, Ed., "HTTP/1.1, part 2: Message | |||
Semantics", draft-ietf-httpbis-p2-semantics-01 (work in | Semantics", draft-ietf-httpbis-p2-semantics-02 (work in | |||
progress), January 2008. | progress), February 2008. | |||
[Part3] Fielding, R., Ed., Gettys, J., Mogul, J., Frystyk, H., | [Part3] Fielding, R., Ed., Gettys, J., Mogul, J., Frystyk, H., | |||
Masinter, L., Leach, P., Berners-Lee, T., Lafon, Y., Ed., | Masinter, L., Leach, P., Berners-Lee, T., Lafon, Y., Ed., | |||
and J. Reschke, Ed., "HTTP/1.1, part 3: Message Payload | and J. Reschke, Ed., "HTTP/1.1, part 3: Message Payload | |||
and Content Negotiation", draft-ietf-httpbis-p3-payload-01 | and Content Negotiation", draft-ietf-httpbis-p3-payload-02 | |||
(work in progress), January 2008. | (work in progress), February 2008. | |||
[Part4] Fielding, R., Ed., Gettys, J., Mogul, J., Frystyk, H., | [Part4] Fielding, R., Ed., Gettys, J., Mogul, J., Frystyk, H., | |||
Masinter, L., Leach, P., Berners-Lee, T., Lafon, Y., Ed., | Masinter, L., Leach, P., Berners-Lee, T., Lafon, Y., Ed., | |||
and J. Reschke, Ed., "HTTP/1.1, part 4: Conditional | and J. Reschke, Ed., "HTTP/1.1, part 4: Conditional | |||
Requests", draft-ietf-httpbis-p4-conditional-01 (work in | Requests", draft-ietf-httpbis-p4-conditional-02 (work in | |||
progress), January 2008. | progress), February 2008. | |||
[Part5] Fielding, R., Ed., Gettys, J., Mogul, J., Frystyk, H., | [Part5] Fielding, R., Ed., Gettys, J., Mogul, J., Frystyk, H., | |||
Masinter, L., Leach, P., Berners-Lee, T., Lafon, Y., Ed., | Masinter, L., Leach, P., Berners-Lee, T., Lafon, Y., Ed., | |||
and J. Reschke, Ed., "HTTP/1.1, part 5: Range Requests and | and J. Reschke, Ed., "HTTP/1.1, part 5: Range Requests and | |||
Partial Responses", draft-ietf-httpbis-p5-range-01 (work | Partial Responses", draft-ietf-httpbis-p5-range-02 (work | |||
in progress), January 2008. | in progress), February 2008. | |||
[Part7] Fielding, R., Ed., Gettys, J., Mogul, J., Frystyk, H., | [Part7] Fielding, R., Ed., Gettys, J., Mogul, J., Frystyk, H., | |||
Masinter, L., Leach, P., Berners-Lee, T., Lafon, Y., Ed., | Masinter, L., Leach, P., Berners-Lee, T., Lafon, Y., Ed., | |||
and J. Reschke, Ed., "HTTP/1.1, part 7: Authentication", | and J. Reschke, Ed., "HTTP/1.1, part 7: Authentication", | |||
draft-ietf-httpbis-p7-auth-01 (work in progress), | draft-ietf-httpbis-p7-auth-02 (work in progress), | |||
January 2008. | February 2008. | |||
[RFC2047] Moore, K., "MIME (Multipurpose Internet Mail Extensions) | [RFC2047] Moore, K., "MIME (Multipurpose Internet Mail Extensions) | |||
Part Three: Message Header Extensions for Non-ASCII Text", | Part Three: Message Header Extensions for Non-ASCII Text", | |||
RFC 2047, November 1996. | RFC 2047, November 1996. | |||
[RFC2119] Bradner, S., "Key words for use in RFCs to Indicate | [RFC2119] Bradner, S., "Key words for use in RFCs to Indicate | |||
Requirement Levels", BCP 14, RFC 2119, March 1997. | Requirement Levels", BCP 14, RFC 2119, March 1997. | |||
19.2. Informative References | 20.2. Informative References | |||
[RFC1305] Mills, D., "Network Time Protocol (Version 3) | [RFC1305] Mills, D., "Network Time Protocol (Version 3) | |||
Specification, Implementation", RFC 1305, March 1992. | Specification, Implementation", RFC 1305, March 1992. | |||
[RFC2616] Fielding, R., Gettys, J., Mogul, J., Frystyk, H., | [RFC2616] Fielding, R., Gettys, J., Mogul, J., Frystyk, H., | |||
Masinter, L., Leach, P., and T. Berners-Lee, "Hypertext | Masinter, L., Leach, P., and T. Berners-Lee, "Hypertext | |||
Transfer Protocol -- HTTP/1.1", RFC 2616, June 1999. | Transfer Protocol -- HTTP/1.1", RFC 2616, June 1999. | |||
Appendix A. Compatibility with Previous Versions | Appendix A. Compatibility with Previous Versions | |||
A.1. Changes from RFC 2068 | A.1. Changes from RFC 2068 | |||
A case was missed in the Cache-Control model of HTTP/1.1; s-maxage | A case was missed in the Cache-Control model of HTTP/1.1; s-maxage | |||
was introduced to add this missing case. (Sections 5, 15.2, 15.2.3) | was introduced to add this missing case. (Sections 6, 16.2, 16.2.3) | |||
Transfer-coding and message lengths all interact in ways that | Transfer-coding and message lengths all interact in ways that | |||
required fixing exactly when chunked encoding is used (to allow for | required fixing exactly when chunked encoding is used (to allow for | |||
transfer encoding that may not be self delimiting); it was important | transfer encoding that may not be self delimiting); it was important | |||
to straighten out exactly how message lengths are computed. | to straighten out exactly how message lengths are computed. | |||
(Section 6.2, see also [Part1], [Part3] and [Part5]) | (Section 7.2, see also [Part1], [Part3] and [Part5]) | |||
Proxies should be able to add Content-Length when appropriate. | Proxies should be able to add Content-Length when appropriate. | |||
(Section 6.2) | (Section 7.2) | |||
Range request responses would become very verbose if all meta-data | Range request responses would become very verbose if all meta-data | |||
were always returned; by allowing the server to only send needed | were always returned; by allowing the server to only send needed | |||
headers in a 206 response, this problem can be avoided. | headers in a 206 response, this problem can be avoided. | |||
(Section 6.3) | (Section 7.3) | |||
The Cache-Control: max-age directive was not properly defined for | The Cache-Control: max-age directive was not properly defined for | |||
responses. (Section 15.2.3) | responses. (Section 16.2.3) | |||
Warnings could be cached incorrectly, or not updated appropriately. | Warnings could be cached incorrectly, or not updated appropriately. | |||
(Section 2.2, 3.4, 6.2, 6.3, 15.2.3, and 15.6) Warning also needed to | (Section 3.2, 4.4, 7.2, 7.3, 16.2.3, and 16.6) Warning also needed to | |||
be a general header, as PUT or other methods may have need for it in | be a general header, as PUT or other methods may have need for it in | |||
requests. | requests. | |||
A.2. Changes from RFC 2616 | A.2. Changes from RFC 2616 | |||
Clarify denial of service attack avoidance requirement. (Section 11) | Clarify denial of service attack avoidance requirement. (Section 12) | |||
Appendix B. Change Log (to be removed by RFC Editor before publication) | Appendix B. Change Log (to be removed by RFC Editor before publication) | |||
B.1. Since RFC2616 | B.1. Since RFC2616 | |||
Extracted relevant partitions from [RFC2616]. | Extracted relevant partitions from [RFC2616]. | |||
B.2. Since draft-ietf-httpbis-p6-cache-00 | B.2. Since draft-ietf-httpbis-p6-cache-00 | |||
Closed issues: | Closed issues: | |||
skipping to change at page 46, line 24 | skipping to change at page 45, line 46 | |||
up-to-date references" | up-to-date references" | |||
o <http://www3.tools.ietf.org/wg/httpbis/trac/ticket/87>: "typo in | o <http://www3.tools.ietf.org/wg/httpbis/trac/ticket/87>: "typo in | |||
13.2.2" | 13.2.2" | |||
Other changes: | Other changes: | |||
o Use names of RFC4234 core rules DQUOTE and HTAB (work in progress | o Use names of RFC4234 core rules DQUOTE and HTAB (work in progress | |||
on <http://www3.tools.ietf.org/wg/httpbis/trac/ticket/36>) | on <http://www3.tools.ietf.org/wg/httpbis/trac/ticket/36>) | |||
B.3. Since draft-ietf-httpbis-p6-cache-01 | ||||
Closed issues: | ||||
o <http://www3.tools.ietf.org/wg/httpbis/trac/ticket/82>: "rel_path | ||||
not used" | ||||
Other changes: | ||||
o Get rid of duplicate BNF rule names ("host" -> "uri-host") (work | ||||
in progress on | ||||
<http://www3.tools.ietf.org/wg/httpbis/trac/ticket/36>) | ||||
o Add explicit references to BNF syntax and rules imported from | ||||
other parts of the specification. | ||||
Index | Index | |||
A | A | |||
age 7 | age 7 | |||
Age header 27 | Age header 27 | |||
C | C | |||
cache 5 | cache 5 | |||
Cache Directives | Cache Directives | |||
max-age 32 | ||||
max-age 33 | max-age 33 | |||
max-age 34 | max-stale 32 | |||
max-stale 33 | min-fresh 32 | |||
min-fresh 33 | must-revalidate 34 | |||
must-revalidate 35 | no-cache 29 | |||
no-cache 30 | no-store 30 | |||
no-store 31 | no-transform 35 | |||
no-transform 36 | only-if-cached 34 | |||
only-if-cached 35 | private 29 | |||
private 30 | proxy-revalidate 35 | |||
proxy-revalidate 36 | public 29 | |||
public 30 | s-maxage 31 | |||
s-maxage 32 | Cache-Control header 27 | |||
Cache-Control header 28 | ||||
cacheable 6 | cacheable 6 | |||
E | E | |||
Expires header 37 | Expires header 37 | |||
explicit expiration time 6 | explicit expiration time 7 | |||
F | F | |||
first-hand 6 | first-hand 6 | |||
fresh 7 | fresh 7 | |||
freshness lifetime 7 | freshness lifetime 7 | |||
G | G | |||
Grammar | Grammar | |||
Age 27 | Age 27 | |||
age-value 27 | age-value 27 | |||
Cache-Control 29 | Cache-Control 28 | |||
cache-directive 29 | cache-directive 28 | |||
cache-extension 29 | cache-extension 28 | |||
cache-request-directive 29 | cache-request-directive 28 | |||
cache-response-directive 29 | cache-response-directive 28 | |||
delta-seconds 27 | delta-seconds 27 | |||
Expires 38 | Expires 37 | |||
extension-pragma 39 | extension-pragma 38 | |||
Pragma 39 | Pragma 38 | |||
pragma-directive 39 | pragma-directive 38 | |||
Vary 39 | Vary 38 | |||
warn-agent 40 | warn-agent 40 | |||
warn-code 40 | warn-code 40 | |||
warn-date 40 | warn-date 40 | |||
warn-text 40 | warn-text 40 | |||
Warning 40 | Warning 40 | |||
warning-value 40 | warning-value 40 | |||
H | H | |||
Headers | Headers | |||
Age 27 | Age 27 | |||
Cache-Control 28 | Cache-Control 27 | |||
Expires 37 | Expires 37 | |||
Pragma 38 | Pragma 38 | |||
Vary 39 | Vary 38 | |||
Warning 40 | Warning 39 | |||
heuristic expiration time 7 | heuristic expiration time 7 | |||
M | M | |||
max-age | max-age | |||
Cache Directive 32 | ||||
Cache Directive 33 | Cache Directive 33 | |||
Cache Directive 34 | ||||
max-stale | max-stale | |||
Cache Directive 33 | Cache Directive 32 | |||
min-fresh | min-fresh | |||
Cache Directive 33 | Cache Directive 32 | |||
must-revalidate | must-revalidate | |||
Cache Directive 35 | Cache Directive 34 | |||
N | N | |||
no-cache | no-cache | |||
Cache Directive 30 | Cache Directive 29 | |||
no-store | no-store | |||
Cache Directive 31 | Cache Directive 30 | |||
no-transform | no-transform | |||
Cache Directive 36 | Cache Directive 35 | |||
O | O | |||
only-if-cached | only-if-cached | |||
Cache Directive 35 | Cache Directive 34 | |||
P | P | |||
Pragma header 38 | Pragma header 38 | |||
private | private | |||
Cache Directive 30 | Cache Directive 29 | |||
proxy-revalidate | proxy-revalidate | |||
Cache Directive 36 | Cache Directive 35 | |||
public | public | |||
Cache Directive 30 | Cache Directive 29 | |||
S | S | |||
s-maxage | s-maxage | |||
Cache Directive 32 | Cache Directive 31 | |||
semantically transparent 5 | semantically transparent 5 | |||
stale 7 | stale 7 | |||
V | V | |||
validator 7 | validator 7 | |||
Vary header 39 | Vary header 38 | |||
W | W | |||
Warning header 40 | Warning header 39 | |||
Authors' Addresses | Authors' Addresses | |||
Roy T. Fielding (editor) | Roy T. Fielding (editor) | |||
Day Software | Day Software | |||
23 Corporate Plaza DR, Suite 280 | 23 Corporate Plaza DR, Suite 280 | |||
Newport Beach, CA 92660 | Newport Beach, CA 92660 | |||
USA | USA | |||
Phone: +1-949-706-5300 | Phone: +1-949-706-5300 | |||
End of changes. 156 change blocks. | ||||
327 lines changed or deleted | 315 lines changed or added | |||
This html diff was produced by rfcdiff 1.34. The latest version is available from http://tools.ietf.org/tools/rfcdiff/ |