|
147 | 147 | A <x:dfn>shared cache</x:dfn> is a cache that stores responses for reuse
|
148 | 148 | by more than one user; shared caches are usually (but not always) deployed
|
149 | 149 | as a part of an intermediary. A <x:dfn>private cache</x:dfn>, in contrast,
|
150 |
| - is dedicated to a single user; often, they are deployed as a component of |
| 150 | + is dedicated to a single user; often, they are deployed as a component of |
151 | 151 | a user agent.
|
152 | 152 | </t>
|
153 | 153 | <t>
|
|
187 | 187 | <xref target="RFC5234"/>, extended with the notation for case-sensitivity
|
188 | 188 | in strings defined in <xref target="RFC7405"/>.
|
189 | 189 | </t>
|
190 |
| -<t> |
| 190 | +<t> |
191 | 191 | It also uses a list extension, defined in <xref target="abnf.extension"/>,
|
192 | 192 | that allows for compact definition of comma-separated lists using a '#'
|
193 | 193 | operator (similar to how the '*' operator indicates repetition). <xref
|
|
237 | 237 | </t>
|
238 | 238 | <aside>
|
239 | 239 | <t>
|
240 |
| - &Note; The value 2147483648 is here for historical reasons, |
| 240 | + &Note; The value 2147483648 is here for historical reasons, |
241 | 241 | represents infinity (over 68 years), and does not need to be stored in
|
242 | 242 | binary form; an implementation could produce it as a canned string if
|
243 | 243 | any overflow occurs, even if the calculations are performed with an
|
|
288 | 288 | Most commonly, caches store the successful result of a retrieval
|
289 | 289 | request: i.e., a <x:ref>200 (OK)</x:ref> response to a GET request, which
|
290 | 290 | contains a representation of the target resource
|
291 |
| - (<xref target="GET"/>). However, it is also possible to store |
| 291 | + (<xref target="GET"/>). However, it is also possible to store |
292 | 292 | redirects, negative results (e.g., <x:ref>404 (Not Found)</x:ref>),
|
293 | 293 | incomplete results (e.g., <x:ref>206 (Partial Content)</x:ref>), and
|
294 | 294 | responses to methods other than GET if the method's definition allows such
|
|
344 | 344 | </li>
|
345 | 345 | </ul>
|
346 | 346 | <t>
|
347 |
| - Note that a cache-control extension can override any of the requirements |
| 347 | + Note that a cache-control extension can override any of the requirements |
348 | 348 | listed; see <xref target="cache.control.extensions" />.
|
349 | 349 | </t>
|
350 | 350 | <t>
|
|
562 | 562 | need to be forwarded to be satisfied.
|
563 | 563 | </t>
|
564 | 564 | <t>
|
565 |
| - When more than one suitable response is stored, a cache &MUST; use the |
| 565 | + When more than one suitable response is stored, a cache &MUST; use the |
566 | 566 | most recent one (as determined by the <x:ref>Date</x:ref> header
|
567 | 567 | field). It can also forward the request with "Cache-Control: max-age=0" or
|
568 | 568 | "Cache-Control: no-cache" to disambiguate which response to use.
|
|
626 | 626 | </t>
|
627 | 627 | <t>
|
628 | 628 | Some resources mistakenly omit the Vary header field from their default
|
629 |
| - response (i.e., the one sent when no more preferable response is available), |
630 |
| - with the effect of selecting it for requests to that resource even when |
| 629 | + response (i.e., the one sent when no more preferable response is available), |
| 630 | + with the effect of selecting it for requests to that resource even when |
631 | 631 | more preferable responses are available. When a cache has multiple responses for a
|
632 | 632 | target URI and one or more omits the Vary header field, it &SHOULD; use the
|
633 | 633 | most recent (see <xref target="age.calculations"/>) valid Vary field value available to select an appropriate response
|
634 | 634 | for the request.
|
635 | 635 | </t>
|
636 | 636 | <t>
|
637 |
| - If no selected response is available, the cache cannot satisfy the |
638 |
| - presented request. Typically, it is forwarded to the origin server |
| 637 | + If no selected response is available, the cache cannot satisfy the |
| 638 | + presented request. Typically, it is forwarded to the origin server |
639 | 639 | in a (possibly conditional; see <xref target="validation.model"/>) request.
|
640 | 640 | </t>
|
641 | 641 | </section>
|
|
663 | 663 | <iref item="age" />
|
664 | 664 | <t>
|
665 | 665 | A response's <x:dfn>age</x:dfn> is the time that has passed since it was
|
666 |
| - generated by, or successfully validated with, the origin server. |
| 666 | + generated by, or successfully validated with, the origin server. |
667 | 667 | </t>
|
668 | 668 | <t>
|
669 | 669 | When a response is fresh, it can be used to satisfy
|
|
713 | 713 | When calculating freshness, to avoid common problems in date parsing:
|
714 | 714 | </t>
|
715 | 715 | <ul>
|
716 |
| - <li>Although all date formats are specified to be case-sensitive, |
| 716 | + <li>Although all date formats are specified to be case-sensitive, |
717 | 717 | a cache recipient &SHOULD; match the field value
|
718 | 718 | case-insensitively.</li>
|
719 | 719 | <li>If a cache recipient's internal implementation of time has less
|
|
870 | 870 | apparent_age = max(0, response_time - date_value);
|
871 | 871 |
|
872 | 872 | response_delay = response_time - request_time;
|
873 |
| - corrected_age_value = age_value + response_delay; |
| 873 | + corrected_age_value = age_value + response_delay; |
874 | 874 | </artwork>
|
875 | 875 | <t>
|
876 | 876 | The corrected_age_value &MAY; be used as the corrected_initial_age. In
|
|
1095 | 1095 | recent of those matching stored responses is identified for update.
|
1096 | 1096 | </li>
|
1097 | 1097 | <li>
|
1098 |
| - If the new response does not include any form of validator (such as |
| 1098 | + If the new response does not include any form of validator (such as |
1099 | 1099 | where a client generates an <x:ref>If-Modified-Since</x:ref> request from
|
1100 | 1100 | a source other than the <x:ref>Last-Modified</x:ref> response header
|
1101 | 1101 | field), and there is only one stored response, and that stored response
|
|
1243 | 1243 | </t>
|
1244 | 1244 | <t>
|
1245 | 1245 | A proxy, whether or not it implements a cache, &MUST; pass cache directives
|
1246 |
| - through in forwarded messages, regardless of their |
1247 |
| - significance to that application, since the directives might apply |
1248 |
| - to all recipients along the request/response chain. It is not possible to |
| 1246 | + through in forwarded messages, regardless of their |
| 1247 | + significance to that application, since the directives might apply |
| 1248 | + to all recipients along the request/response chain. It is not possible to |
1249 | 1249 | target a directive to a specific cache.
|
1250 | 1250 | </t>
|
1251 | 1251 | <t>
|
|
1345 | 1345 | validation on the origin server.
|
1346 | 1346 | </t>
|
1347 | 1347 | </section>
|
1348 |
| - |
| 1348 | + |
1349 | 1349 | <section title="no-store" anchor="cache-request-directive.no-store">
|
1350 | 1350 | <iref item="no-store (cache directive)" primary="true" />
|
1351 | 1351 | <t>
|
|
1418 | 1418 | e.g., 'max-age=5' not 'max-age="5"'. A sender &MUST-NOT; generate the
|
1419 | 1419 | quoted-string form.
|
1420 | 1420 | </t>
|
1421 |
| -</section> |
| 1421 | +</section> |
1422 | 1422 |
|
1423 | 1423 | <section title="must-revalidate" anchor="cache-response-directive.must-revalidate">
|
1424 | 1424 | <iref item="must-revalidate (cache directive)" primary="true" />
|
|
1495 | 1495 | This allows an origin server to prevent the re-use of certain header
|
1496 | 1496 | fields in a response, while still allowing caching of the rest of the
|
1497 | 1497 | response.
|
1498 |
| -</t> |
| 1498 | +</t> |
1499 | 1499 | <t>
|
1500 | 1500 | The field names given are not limited to the set of header
|
1501 | 1501 | fields defined by this specification. Field names are case-insensitive.
|
|
1625 | 1625 | is already cacheable according to <xref target="response.cacheability"/>.
|
1626 | 1626 | </t>
|
1627 | 1627 | <t>
|
1628 |
| - If a response with the public directive has no explicit freshness information, |
| 1628 | + If a response with the public directive has no explicit freshness information, |
1629 | 1629 | it is heuristically cacheable (<xref target="heuristic.freshness"/>).
|
1630 | 1630 | </t>
|
1631 | 1631 | </section>
|
|
1674 | 1674 | Informational extensions (those that do not require a change in cache
|
1675 | 1675 | behavior) can be added without changing the semantics of other directives.
|
1676 | 1676 | </t>
|
1677 |
| -<t> |
| 1677 | +<t> |
1678 | 1678 | Behavioral extensions are designed to work by acting as modifiers to the
|
1679 | 1679 | existing base of cache directives.
|
1680 | 1680 | Both the new directive and the old directive are supplied, such that
|
|
1781 | 1781 | with a reliable clock.
|
1782 | 1782 | </t>
|
1783 | 1783 | <t>
|
1784 |
| - Historically, HTTP required the Expires field value to be no more than a |
1785 |
| - year in the future. While longer freshness lifetimes are no longer |
1786 |
| - prohibited, extremely large values have been demonstrated to cause |
1787 |
| - problems (e.g., clock overflows due to use of 32-bit integers for |
1788 |
| - time values), and many caches will evict a response far sooner than |
| 1784 | + Historically, HTTP required the Expires field value to be no more than a |
| 1785 | + year in the future. While longer freshness lifetimes are no longer |
| 1786 | + prohibited, extremely large values have been demonstrated to cause |
| 1787 | + problems (e.g., clock overflows due to use of 32-bit integers for |
| 1788 | + time values), and many caches will evict a response far sooner than |
1789 | 1789 | that.
|
1790 | 1790 | </t>
|
1791 | 1791 | </section>
|
|
1910 | 1910 | <t>
|
1911 | 1911 | Because one of the primary uses of a cache is to optimise performance,
|
1912 | 1912 | its use can "leak" information about what resources have been previously
|
1913 |
| - requested. |
| 1913 | + requested. |
1914 | 1914 | </t>
|
1915 | 1915 | <t>
|
1916 | 1916 | For example, if a user visits a site and their browser caches some of its
|
|
1953 | 1953 | <section title="Field Name Registration" anchor="field.name.registration">
|
1954 | 1954 | <t>
|
1955 | 1955 | First, introduce the new "Hypertext Transfer Protocol (HTTP) Field
|
1956 |
| - Name Registry" at <eref target="https://www.iana.org/assignments/http-fields"/> |
1957 |
| - as described in |
1958 |
| - <xref target="Semantics" x:rel="#field.name.registration"/>. |
| 1956 | + Name Registry" at <eref target="https://www.iana.org/assignments/http-fields"/> |
| 1957 | + as described in |
| 1958 | + <xref target="Semantics" x:rel="#field.name.registration"/>. |
1959 | 1959 | </t>
|
1960 | 1960 | <t>
|
1961 | 1961 | Then, please update the registry with the field names listed in the table
|
|
2136 | 2136 | <references title="Normative References">
|
2137 | 2137 |
|
2138 | 2138 | <reference anchor="Messaging">
|
2139 |
| - <x:source basename="draft-ietf-httpbis-messaging-latest" href="draft-ietf-httpbis-messaging-latest.xml"> |
| 2139 | + <x:source basename="draft-ietf-httpbis-messaging-latest" href="rfc9110.xml"> |
2140 | 2140 | <x:has anchor="message.body.length"/>
|
2141 | 2141 | </x:source>
|
2142 | 2142 | </reference>
|
2143 | 2143 |
|
2144 | 2144 | <reference anchor="Semantics">
|
2145 |
| - <x:source basename="draft-ietf-httpbis-semantics-latest" href="draft-ietf-httpbis-semantics-latest.xml"> |
| 2145 | + <x:source basename="draft-ietf-httpbis-semantics-latest" href="rfc9112.xml"> |
2146 | 2146 | <x:defines>Content-Length</x:defines>
|
2147 | 2147 | <x:has anchor="GET"/>
|
2148 | 2148 | <x:has anchor="abnf.extension"/>
|
|
2250 | 2250 | </front>
|
2251 | 2251 | <seriesInfo name="RFC" value="7234"/>
|
2252 | 2252 | </reference>
|
2253 |
| - |
| 2253 | + |
2254 | 2254 | <reference anchor='RFC5861'>
|
2255 | 2255 | <front>
|
2256 | 2256 | <title abbrev="HTTP stale controls">HTTP Cache-Control Extensions for Stale Content</title>
|
|
2292 | 2292 | <seriesInfo name="BCP" value="26"/>
|
2293 | 2293 | <seriesInfo name="RFC" value="8126"/>
|
2294 | 2294 | </reference>
|
2295 |
| - |
| 2295 | + |
2296 | 2296 | </references>
|
2297 | 2297 |
|
2298 | 2298 | <?BEGININC build/draft-ietf-httpbis-cache-latest.abnf-appendix ?>
|
|
0 commit comments