Skip to content Skip to sidebar Skip to footer

How To Prevent Browsers From Caching An Image?

I have one image on my website that I don't want cached. The image is used as a background in CSS so I can not change it's name dynamically. Any ideas ?

Solution 1:

Another alternative would be to add a random string after your image file.

<imgsrc="/path/to/image/image.jpg?<?phpecho time(); ?>/>

This should ensure that the image is reloaded each time the page is displayed.

Solution 2:

mnot has a good caching tutorial that will explain how to set the HTTP headers to request that the image is not cached (remember, you need to set the HTTP headers for the image, not the HTML document).

This is probably a bad idea though as images tend to be relatively chunky, so redownloading it for every page could impose a significant performance slow down.

Solution 3:

with apache you cant achieve this in 2 different ways:

with mod_headers:

<FilesMatch "\.(png|jpg|jpeg|jpeg)$">
Header set Expires "Fri, 04 Aug 1978 12:00:00 GMT"
Header set Cache-Control "no-cache, no-store, must-revalidate, max-age=0, proxy-revalidate, no-transform"
Header set Pragma "no-cache"
</FilesMatch>

or with mod_expires:

<IfModule mod_expires.c>
  ExpiresActive On
  ExpiresByType image/png A0
  ExpiresByType image/gif A0
  ExpiresByType image/jpg A0
  ExpiresByType image/jpeg A0
</IfModule>

Solution 4:

If you can't set up caching rules on Apache (as suggested by @David Dorvard's answer - see the part using the <Files directive), you could pipe the image through a PHP script, and set your own (no)caching headers there:

<?php 
header('Cache-Control: no-cache');
header('Expires: 0');
header('Content-Type: image/jpeg'); // or whatever your image is
readfile('/some/path/to/yourfile.jpg');
?>

This should get you an image that's not cached at all; emphasis on should, as various browsers are variously broken (IIRC IE6 cached it anyway when linked as background-image, but thankfully that's on the way out).

Note that this simplistic approach will 1) increase the load on the server as it needs to start PHP for the image request and 2) disable partial download on the script/image

Solution 5:

If you are targeting modern browsers you could use an HTML5 Manifest file: http://diveintohtml5.ep.io/offline.html#network

Post a Comment for "How To Prevent Browsers From Caching An Image?"