Skip to content

Cookies

Cookies

Unusual Cookies

Source

Changes to Cookies

Google Chrome

Expires Flag

  • Uses a finite date to expire a cookie. Ex. Expires=Wed, 21 Oct 2015 07:28:00 GMT
  • If this is not set then the cookie expires when the session is closed.
    • If a browser session is restored as part of a option by the browser then the session is never closed.

Max-Age Flag

  • Used to set an auto expiration client side of the cookie.
  • This is done in the number of seconds that it is valid for
  • If both Expires and Max-age flags are set Max-age has priority

Domain Flag

  • If the domain flag is not set then the current full domain not including subdomains is set.
  • It is not possible to set more than one host/domain values are not allowed,
  • If a domain is manually specified in then all subdomains are included

Path Flag

  • Specify only a certain directory and subdirectory with this attribute

Secure Flag

  • http sites cannot set https headers
  • only sent if the server is using SSL/TLS

HttpOnly Flag

  • Restricts JavaScript from accessing the cookie
  • This cookie will still be sent with JavaScript-initiated requests

SameSite Flag

Same site also includes subdomains.
google.com cookies will work for mail.google.com

Note

If samesite is not set on a cookie then it can be used cross-site for 2mins after it is set. This is used to not break OAUTH flow

HTTP External Endpoint:

IFRAME/IMG XS GET XS POST XS PUT/DELETE/ETC XS HEAD
SameSite=Strict No No No No No
SameSite=None No No No No No
SameSite=Lax No Yes No No Yes
Secure & SameSite=None No No No No No
no SameSite No Yes Yes (for 2 mins) Yes (for 2 mins) Yes
SameSite=invalid No Yes Yes (for 2 mins) Yes (for 2 mins) Yes

HTTPS External Endpoint:

IFRAME/IMG XS GET XS POST XS PUT/DELETE/ETC XS HEAD
SameSite=Strict No No No No No
SameSite=None No No No No No
SameSite=Lax No Yes No No Yes
Secure & SameSite=None Yes Yes Yes Yes Yes
no SameSite No Yes Yes (for 2 mins) Yes (for 2 mins) Yes
SameSite=invalid No Yes Yes (for 2 mins) Yes (for 2 mins) Yes