The Hypertext Transfer Protocol Status Code 308 (Permanent Redirect)greenbytes GmbHHafenweg 16MuensterNW48155Germanyjulian.reschke@greenbytes.dehttp://greenbytes.de/tech/webdav/
Applications
HTTPbis Working GroupHTTPredirectstatus code
This document specifies the additional Hypertext Transfer Protocol (HTTP)
status code 308 (Permanent Redirect).
HTTP defines a set of status codes for the purpose of redirecting a request
to a different URI (). The history of these status codes is summarized in
Section 6.4 of , which
also classifies the existing status codes into four categories.
The first of these categories contains the status codes 301 (Moved Permanently),
302 (Found), and 307 (Temporary Redirect), which can be classified as below:
PermanentTemporaryAllows changing the request method from POST to GET301302Does not allow changing the request method from POST to GET-307
Section 6.4.7 of
states that HTTP does not define a permanent variant of status code 307;
this specification adds
the status code 308, defining this missing variant ().
This specification contains no technical changes from the experimental RFC 7238,
which it obsoletes.
The key words "MUST", "MUST NOT", "REQUIRED", "SHALL", "SHALL NOT",
"SHOULD", "SHOULD NOT", "RECOMMENDED", "MAY", and "OPTIONAL" in this
document are to be interpreted as described in .
The 308 (Permanent Redirect) status code indicates that the
target resource has been assigned a new permanent URI and
any future references to this resource ought to use one of the enclosed
URIs. Clients with link editing capabilities ought to automatically re-link
references to the effective request URI (Section 5.5 of )
to one or more of the new references sent by the server, where possible.
The server SHOULD generate a Location header field (, Section 7.1.2) in the
response containing a preferred URI reference for the new permanent URI.
The user agent MAY use the Location field value for automatic redirection.
The server's response payload usually contains a short hypertext note with
a hyperlink to the new URI(s).
A 308 response is cacheable by default; i.e., unless otherwise indicated by
the method definition or explicit cache controls (see , Section 4.2.2).
Note: This status code is similar to 301 (Moved Permanently) (, Section 6.4.2), except
that it does not allow changing the request method from POST to GET.
Section 6 of
requires recipients to treat unknown 3xx status codes the same way as
status code 300 Multiple Choices (, Section 6.4.1).
Thus, servers will not be able to rely on automatic redirection happening
similar to status codes 301, 302, or 307.
Therefore, initial use of status code 308 will be restricted to cases where
the server has sufficient confidence in the client's understanding the new
code or when a fallback to the semantics of status code 300 is not problematic.
Server implementers are advised not to vary the status code based on
characteristics of the request, such as the User-Agent header field
("User-Agent Sniffing") — doing so usually results in code that is both
hard to maintain and hard to debug and would also require special attention to caching
(i.e., setting a "Vary" response header field, as defined in
Section 7.1.4 of ).
Note that many existing HTML-based user agents will emulate a refresh when encountering
an HTML <meta> refresh directive (). This can be used as another
fallback. For example:
All security considerations that apply to HTTP redirects apply to the
308 status code as well (see Section 9 of ).
The registration below has been added to the "Hypertext Transfer Protocol (HTTP) Status Code Registry"
(defined in Section 8.2 of
and located at ):
ValueDescriptionReference308Permanent Redirect of this specification
The definition for the new status code 308 reuses text from
the HTTP/1.1 definitions of status codes 301 and 307.
Furthermore, thanks to Ben Campbell, Cyrus Daboo, Eran Hammer-Lahav, Bjoern Hoehrmann,
Subramanian Moonesamy, Peter Saint-Andre,
and Robert Sparks for feedback on this document.
Key words for use in RFCs to Indicate Requirement LevelsHarvard Universitysob@harvard.eduUniform Resource Identifier (URI): Generic SyntaxWorld Wide Web Consortiumtimbl@w3.orghttp://www.w3.org/People/Berners-Lee/Day Softwarefielding@gbiv.comhttp://roy.gbiv.com/Adobe Systems IncorporatedLMM@acm.orghttp://larry.masinter.net/Hypertext Transfer Protocol (HTTP/1.1): Message Syntax and RoutingAdobe Systems Incorporatedfielding@gbiv.comgreenbytes GmbHjulian.reschke@greenbytes.deHypertext Transfer Protocol (HTTP/1.1): Semantics and ContentAdobe Systems Incorporatedfielding@gbiv.comgreenbytes GmbHjulian.reschke@greenbytes.deHypertext Transfer Protocol (HTTP/1.1): CachingAdobe Systems Incorporatedfielding@gbiv.comRackspacemnot@mnot.netgreenbytes GmbHjulian.reschke@greenbytes.deHTML 4.01 Specification
Latest version available at
.