files/en-us/web/http/reference/headers/clear-site-data/index.md
{{securecontext_header}}
The HTTP Clear-Site-Data {{Glossary("response header")}} sends a signal to the client that it should remove all browsing data of certain types (cookies, storage, cache) associated with the requesting website.
It allows web developers to have more control over the data stored by browsers for their origins.
// Single directive
Clear-Site-Data: "cache"
// Multiple directives (comma separated)
Clear-Site-Data: "cache", "cookies"
// Wild card
Clear-Site-Data: "*"
[!NOTE] All directives must comply with the quoted-string grammar. A directive that does not include the double quotes is invalid.
"cache"
"clientHints" {{Experimental_Inline}}
: Indicates that the server will remove all client hints (requested via {{HTTPHeader("Accept-CH")}}) stored for the origin of the response URL.
[!NOTE] In browsers that support the
"clientHints"data type, client hints are also cleared when the"cache","cookies", or"*"types are specified."clientHints"is therefore only needed when none of those other types are specified.
"cookies"
https://example.com as well as https://stage.example.com, will have cookies cleared."executionContexts" {{Experimental_Inline}}
"prefetchCache" {{experimental_inline}} {{non-standard_inline}}
"prerenderCache" {{experimental_inline}} {{non-standard_inline}}
"storage"
localStorage.clear),sessionStorage.clear),NPP_ClearSiteData)."*" (wildcard)
If a user signs out of your website or service, you might want to remove locally stored data, including any prefetched or prerendered content for {{domxref("Speculation Rules API", "speculated navigations","", "nocode")}}.
To do this, add the Clear-Site-Data header to the page that confirms the logging out from the site has been accomplished successfully (https://example.com/logout, for example):
Clear-Site-Data: "cache", "cookies", "storage", "executionContexts", "prefetchCache", "prerenderCache"
If this header is delivered with the response at https://example.com/clear-cookies, all cookies on the same domain https://example.com and any subdomains (like https://stage.example.com, etc.), will be cleared out.
Clear-Site-Data: "cookies"
If this header is delivered with the response at https://example.com/change-state.json, all {{domxref("Speculation Rules API", "speculated navigations","", "nocode")}} prerenders on the same domain https://example.com and any subdomains (such as https://stage.example.com), will be cleared.
Clear-Site-Data: "prerenderCache"
To clear both prefetch and prerender speculations, both prefetchCache and prerenderCache must be sent:
Clear-Site-Data: "prefetchCache", "prerenderCache"
There are cases where clearing one or the other, or both, is appropriate.
For example, a client-side rendered application that pulls in data from JavaScript might use prerenderCache on state change to discard the prerendered pages, but keep the prefetched HTML to use when the page is rendered (or prerendered again).
On the other hand, if the prefetched HTML document contains stale data but the corresponding prerendered page is set up to refresh the data when it is displayed, you may not need to use prerenderCache but you probably will want to use the prefetchCache directive: so that the stale HTML isn't used in a future prerender.
Finally, if the prefetched HTML document contains stale data, and also does not refresh stale content on prerendered pages, then specifying both prefetchCache and prerenderCache is most appropriate.
{{Specifications}}
{{Compat}}