Set-Cookie header
        
        
          
                Baseline
                
                  Widely available
                
                 *
              
        
        
        
          
                
              
                
              
                
              
        
        
      
      This feature is well established and works across many devices and browser versions. It’s been available across browsers since July 2015.
* Some parts of this feature may have varying levels of support.
The HTTP Set-Cookie response header is used to send a cookie from the server to the user agent, so that the user agent can send it back to the server later.
To send multiple cookies, multiple Set-Cookie headers should be sent in the same response.
Warning:
Browsers block frontend JavaScript code from accessing the Set-Cookie header, as required by the Fetch spec, which defines Set-Cookie as a forbidden response header name that must be filtered out from any response exposed to frontend code.
When a Fetch API or XMLHttpRequest API request uses CORS, browsers will ignore Set-Cookie headers present in the server's response unless the request includes credentials. Visit Using the Fetch API - Including credentials and the XMLHttpRequest article to learn how to include credentials.
For more information, see the guide on Using HTTP cookies.
| Header type | Response header | 
|---|---|
| Forbidden request header | No | 
| Forbidden response header name | Yes | 
Syntax
Set-Cookie: <cookie-name>=<cookie-value>
Set-Cookie: <cookie-name>=<cookie-value>; Domain=<domain-value>
Set-Cookie: <cookie-name>=<cookie-value>; Expires=<date>
Set-Cookie: <cookie-name>=<cookie-value>; HttpOnly
Set-Cookie: <cookie-name>=<cookie-value>; Max-Age=<number>
Set-Cookie: <cookie-name>=<cookie-value>; Partitioned
Set-Cookie: <cookie-name>=<cookie-value>; Path=<path-value>
Set-Cookie: <cookie-name>=<cookie-value>; Secure
Set-Cookie: <cookie-name>=<cookie-value>; SameSite=Strict
Set-Cookie: <cookie-name>=<cookie-value>; SameSite=Lax
Set-Cookie: <cookie-name>=<cookie-value>; SameSite=None; Secure
// Multiple attributes are also possible, for example:
Set-Cookie: <cookie-name>=<cookie-value>; Domain=<domain-value>; Secure; HttpOnly
Attributes
- 
Defines the cookie name and its value. A cookie definition begins with a name-value pair. A <cookie-name>can contain any US-ASCII characters except for control characters (ASCII characters 0 up to 31 and ASCII character 127) or separator characters (space, tab and the characters:( ) < > @ , ; : \ " / [ ] ? = { })A <cookie-value>can optionally be wrapped in double quotes and include any US-ASCII character excluding control characters (ASCII characters 0 up to 31 and ASCII character 127), Whitespace, double quotes, commas, semicolons, and backslashes.Encoding: Many implementations perform percent-encoding on cookie values. However, this is not required by the RFC specification. The percent-encoding does help to satisfy the requirements of the characters allowed for <cookie-value>.Note: Some cookie names contain prefixes that impose specific restrictions on the cookie's attributes in supporting user-agents. See Cookie prefixes for more information. 
- Domain=<domain-value>Optional
- 
Defines the host to which the cookie will be sent. Only the current domain can be set as the value, or a domain of a higher order, unless it is a public suffix. Setting the domain will make the cookie available to it, as well as to all its subdomains. If omitted, this attribute defaults to the host of the current document URL, not including subdomains. Contrary to earlier specifications, leading dots in domain names ( .example.com) are ignored.Multiple host/domain values are not allowed, but if a domain is specified, then subdomains are always included. 
- Expires=<date>Optional
- 
Indicates the maximum lifetime of the cookie as an HTTP-date timestamp. See Datefor the required formatting.If unspecified, the cookie becomes a session cookie. A session finishes when the client shuts down, after which the session cookie is removed. Warning: Many web browsers have a session restore feature that will save all tabs and restore them the next time the browser is used. Session cookies will also be restored, as if the browser was never closed. The Expiresattribute is set by the server with a value relative to its own internal clock, which may differ from that of the client browser. Firefox and Chromium-based browsers internally use an expiry (max-age) value that is adjusted to compensate for clock difference, storing and expiring cookies based on the time intended by the server. The adjustment for clock skew is calculated from the value of theDATEheader. Note that the specification explains how the attribute should be parsed, but does not indicate if/how the value should be corrected by the recipient.
- HttpOnlyOptional
- 
Forbids JavaScript from accessing the cookie, for example, through the Document.cookieproperty. Note that a cookie that has been created withHttpOnlywill still be sent with JavaScript-initiated requests, for example, when callingXMLHttpRequest.send()orfetch(). This mitigates attacks against cross-site scripting (XSS).
- Max-Age=<number>Optional
- 
Indicates the number of seconds until the cookie expires. A zero or negative number will expire the cookie immediately. If both ExpiresandMax-Ageare set,Max-Agehas precedence.
- PartitionedOptional
- 
Indicates that the cookie should be stored using partitioned storage. Note that if this is set, the Securedirective must also be set. See Cookies Having Independent Partitioned State (CHIPS) for more details.
- Path=<path-value>Optional
- 
Indicates the path that must exist in the requested URL for the browser to send the Cookieheader.If omitted, this attribute defaults to the path component of the request URL. For example, if a cookie is set by a request to https://example.com/docs/Web/HTTP/index.html, the default path would be/docs/Web/HTTP/.The forward slash ( /) character is interpreted as a directory separator, and subdirectories are matched as well. For example, forPath=/docs,- the request paths /docs,/docs/,/docs/Web/, and/docs/Web/HTTPwill all match.
- the request paths /,/docsets,/fr/docswill not match.
 Note: The pathattribute lets you control what cookies the browser sends based on the different parts of a site. It is not intended as a security measure, and does not protect against unauthorized reading of the cookie from a different path.
- the request paths 
- SameSite=<samesite-value>Optional
- 
Controls whether or not a cookie is sent with cross-site requests: that is, requests originating from a different site, including the scheme, from the site that set the cookie. This provides some protection against certain cross-site attacks, including cross-site request forgery (CSRF) attacks. The possible attribute values are: - Strict
- 
Send the cookie only for requests originating from the same site that set the cookie. 
- Lax
- 
Send the cookie only for requests originating from the same site that set the cookie, and for cross-site requests that meet both of the following criteria: - 
The request is a top-level navigation: this essentially means that the request causes the URL shown in the browser's address bar to change. - 
This would exclude, for example, requests made using the fetch()API, or requests for subresources from<img>or<script>elements, or navigations inside<iframe>elements.
- 
It would include requests made when the user clicks a link in the top-level browsing context from one site to another, or an assignment to document.location, or a<form>submission.
 
- 
- 
The request uses a safe method: in particular, this excludes POST,PUT, andDELETE.
 Some browsers use Laxas the default value ifSameSiteis not specified: see Browser compatibility for details.Note: When Laxis applied as a default, a more permissive version is used. In this more permissive version, cookies are also included inPOSTrequests, as long as they were set no more than two minutes before the request was made.
- 
- None
- 
Send the cookie with both cross-site and same-site requests. The Secureattribute must also be set when using this value.
 
- SecureOptional
- 
Indicates that the cookie is sent to the server only when a request is made with the https:scheme (except on localhost), and therefore, is more resistant to man-in-the-middle attacks.Note: Do not assume that Secureprevents all access to sensitive information in cookies (session keys, login details, etc.). Cookies with this attribute can still be read/modified either with access to the client's hard disk or from JavaScript if theHttpOnlycookie attribute is not set.Insecure sites ( http:) cannot set cookies with theSecureattribute. Thehttps:requirements are ignored when theSecureattribute is set by localhost.
Cookie prefixes
Some cookie names contain prefixes that impose specific restrictions on the cookie's attributes in supporting user-agents. All cookie prefixes start with a double-underscore (__) and end in a dash (-). The following prefixes are defined:
- __Secure-: Cookies with names starting with- __Secure-must be set with the- Secureattribute by a secure page (HTTPS).
- __Host-: Cookies with names starting with- __Host-must be set with the- Secureattribute by a secure page (HTTPS). In addition, they must not have a- Domainattribute specified, and the- Pathattribute must be set to- /. This guarantees that such cookies are only sent to the host that set them, and not to any other host on the domain. It also guarantees that they are set host-wide and cannot be overridden on any path on that host. This combination yields a cookie that is as close as can be to treating the origin as a security boundary.
- __Http-: Cookies with names starting with- __Http-must be set with the- Secureflag by a secure page (HTTPS) and in addition must have the- HttpOnlyattribute set to prove that they were set via the- Set-Cookieheader (they can't be set or modified via JavaScript features such as- Document.cookieor the Cookie Store API).
- __Host-Http-: Cookies with names starting with- __Host-Http-must be set with the- Secureflag by a secure page (HTTPS) and must have the- HttpOnlyattribute set to prove that they were set via the- Set-Cookieheader. In addition, they also have the same restrictions as- __Host--prefixed cookies. This combination yields a cookie that is as close as can be to treating the origin as a security boundary while at the same time ensuring developers and server operators know that its scope is limited to HTTP requests.
Warning: You cannot count on these additional assurances on browsers that don't support cookie prefixes; in such cases, prefixed cookies will always be accepted.
Examples
>Session cookie
Session cookies are removed when the client shuts down. Cookies are session cookies if they do not specify the Expires or Max-Age attribute.
Set-Cookie: sessionId=38afes7a8
Permanent cookie
Permanent cookies are removed at a specific date (Expires) or after a specific length of time (Max-Age) and not when the client is closed.
Set-Cookie: id=a3fWa; Expires=Wed, 21 Oct 2015 07:28:00 GMT
Set-Cookie: id=a3fWa; Max-Age=2592000
Invalid domains
A cookie for a domain that does not include the server that set it should be rejected by the user agent.
The following cookie will be rejected if set by a server hosted on original-company.com:
Set-Cookie: qwerty=219ffwef9w0f; Domain=some-company.co.uk
A cookie for a subdomain of the serving domain will be rejected.
The following cookie will be rejected if set by a server hosted on example.com:
Set-Cookie: sessionId=e8bb43229de9; Domain=foo.example.com
Cookie prefixes
Cookie names prefixed with __Secure- or __Host- can be used only if they are set with the Secure attribute from a secure (HTTPS) origin.
Cookie names prefixed with __Http- or __Host-Http- can be used only if they are set with the Secure attribute from a secure (HTTPS) origin and in addition must have the HttpOnly attribute set to prove that they were set via the Set-Cookie header and not on the client-side via JavaScript.
In addition, cookies with the __Host- or __Host-Http- prefix must have a path of / (meaning any path at the host) and must not have a Domain attribute.
// Both accepted when from a secure origin (HTTPS)
Set-Cookie: __Secure-ID=123; Secure; Domain=example.com
Set-Cookie: __Host-ID=123; Secure; Path=/
// Rejected due to missing Secure attribute
Set-Cookie: __Secure-id=1
// Rejected due to the missing Path=/ attribute
Set-Cookie: __Host-id=1; Secure
// Rejected due to setting a Domain
Set-Cookie: __Host-id=1; Secure; Path=/; Domain=example.com
// Only settable via Set-Cookie
Set-Cookie: __Http-ID=123; Secure; Domain=example.com
Set-Cookie: __Host-Http-ID=123; Secure; Path=/
Partitioned cookie
Set-Cookie: __Host-example=34d8g; SameSite=None; Secure; Path=/; Partitioned;
Note:
Partitioned cookies must be set with Secure. In addition, it is recommended to use a __Host or __Host-Http- prefix when setting partitioned cookies to make them bound to the hostname and not the registrable domain.
Specifications
| Specification | 
|---|
| HTTP State Management Mechanism> # sane-set-cookie> | 
Browser compatibility
Loading…
See also
- HTTP cookies
- Cookie
- Document.cookie
- Samesite cookies explained (web.dev blog)