Updated about 1 yr, 5 mths ago (July 27, 2023). Know a better answer? Let me know!
Prevent caching of dynamic web pages
This is generally not a problem, because PHP usually generates the headers required to prevent caching automatically. However, should you wish to explicitly generate the headers required to prevent your pages from being cached, here’s how (assuming you’re using PHP and Apache or similar).
Caching is controlled by the HTTP headers sent with every HTTP request. The basic logic is quite simple – if permitted to cache, a cache will store the page for a specified time. This is controlled by the “Cache-Control” and “Expires” headers.
Cache-Control
The “Cache-Control” header instructs modern caches on how they should behave, although it is worth noting that older caches may not obey this field. “Cache-Control” can take a variety of values, such as “private” and “no-cache”. A “public” field in a Cache-Control header indicates that the resource may be cached by any cache. “Private” indicates that the response should only be cached by non-shared caches (such as your local browser), and “no-cache”, rather obviously, indicates that the page or resource being returned must not be cached anywhere.
// tell all caches that they must not cache and revalidate the content. header("Cache-Control: no-cache, must-revalidate"); // HTTP/1.1
Expires
The Expires header gives the date and time after which a response is considered stale, that is, after which a cached copy of a page should no longer be considered valid. In other words, the Expires header indicates how long caches should store a cached copy of a page. Here we indicate that pages can be cached for one month from the current date, by specifying their expiry as a date one month in the future.
// this resource expires in the past header("Expires: Sat, 26 Jul 1997 05:00:00 GMT"); // Date in the past
Not Modified
There’s one further caveat – headers must be sent before any other output. This generally means that headers must be sent before anything else in your PHP code, in other words, that this code must go at the very top of your PHP code before anything else. One way around this is to buffer your page on the server before outputting it, which is done by using ob_start(), which I use to provide gzip compression – further increasing the responsiveness of plain text files by transmitting them compressed, and decreasing the server bandwidth used even more.
All Together Now
Putting all this together gives us:
header("Cache-Control: no-cache, must-revalidate"); // HTTP/1.1 header("Expires: Sat, 26 Jul 1997 05:00:00 GMT"); // Date in the past // start output. // Note that no output can precede the headers unless you call ob_start(). // You don't have to use gzip, but it greatly saves on bandwidth (for text) // at the cost of a little more processing. ob_start("ob_gzhandler");
More Information
For more information on:
- PHP headers, see www.php.net/manual/en/function.header.php
- HTTP headers, see www.freesoft.org/CIE/RFC/2068/155.htm
- ob_start(), see www.php.net/manual/en/function.ob-start.php
- To view the HTTP headers sent by a server, web-sniffer.net
Updated about 1 yr, 5 mths ago (July 27, 2023). Know a better answer? Let me know!
Related categories
.User submitted comments:
Comment on this article (no HTML, max 1200 characters):
Ned, about 10 yrs, 7 mths ago
Sunday June 1, 2014 8:59 AM
This is a test.