1

In a project, client-side in the browser, i dynamically create an <img>-tag and set the source to an image. It is served from apache2 on the host.

The user can then make changes and i sometimes need to reload the image (as the source on the server has changed). I do that by changing the src-attribute to the new image.

The problem is, the old (first) image remains in the cache and no further changes are ever reflected.

I did of course try to prevent caching by the regular means:

  • I change the URL of the source image on every reload, by adding a parameter to the url and setting its value to the current time. I checked to confirm and yes, every load actually requests a different URL from the server, but the image is still served as a cached version.
  • I'm returning a variety of headers to prevent caching. Here is what the response headers look like:

    Access-Control-Allow-Headers: origin, x-requested-with, content-type
    Access-Control-Allow-Methods: PUT, GET, POST, DELETE, OPTIONS
    Cache-control: no-cache, no-store, must-revalidate
    Connection: Keep-Alive
    Content-Length: 48503
    Content-Type: image/png
    Date: Wed, 05 Sep 2018 15:51:08 GMT
    Expires: 0
    Keep-Alive: timeout=5, max=100
    Pragma: no-cache
    Server: Apache/2.4.25 (Debian)
    Set-Cookie: locale=de; Domain=c.test; Path=/; Expires=Mon, 04 Mar 2019 15:51:08 GMT
    Set-Cookie: session_id=563bbb7d216d4edf7aed7e38427e15aec584414a605df6d2481223f840bf13f7; Domain=c.test; Path=/
    

A requested URL looks like this:

/event/590c713b5fd3197a0a16c851/reg/data/streamThumbnail?file=93c180702fd9926d40f77dd19ae48cee.crop.jpg&t=0478533001536162394&dimensions=130x181

Unfortunately i am out of options. I tried debugging this by loading the image src directly in a new tab, making changes on the server and then reloading, but the image remains the same, even though it doesn't exist on the server anymore at all.

Can anyone point me in the right direction here? Does anyone know what is going on or what i've been missing?

I'm sorry i cannot provide any testing outlet for this, so i guess this one's up to the ones who have encountered this problem themselves.

Thank you.

SquareCat
  • 5,699
  • 9
  • 41
  • 75

2 Answers2

0

Tried this? Should work in both .htaccess, httpd.conf and in a VirtualHost

<filesMatch "\.(html|htm|js|css)$">
  FileETag None
  <ifModule mod_headers.c>
     Header unset ETag
     Header set Cache-Control "max-age=0, no-cache, no-store, must-revalidate"
     Header set Pragma "no-cache"
     Header set Expires "Wed, 11 Jan 1984 05:00:00 GMT"
  </ifModule>
</filesMatch>

And optionally add the extension for the template files you are retrieving if you are using an extension other than .html for those.

Diego
  • 699
  • 6
  • 10
-2

You can do this easily client side, with adding a url query. i.e.

<img src="folder/my-image.jpg?cache=1">

Every time you want to refresh the image, increase the number on your cache variable. i.e. make it ?cache=2. A lot of people will use a date/time variable in this field to never allow caching.

EDIT: Okay, sorry, just realized you tried this. Another option is to use data-uri's. If you have the ability to read the image as source, you can use a data-uri in the image tag as a base64 hex string:

<img src="">

I believe there's a size limit on some older versions of Internet Explorer.

EDIT 2: If you are truly looking for a HTTP HEADER option, did you also try the "Expires" value. If I recall, you have to use a negative value, i.e. Expires: -1. There's also a few other cache controls you can play with, like Cache-Control: max-age=0 or Cache-Control: must-revalidate.

EDIT 3: Ok, you did try the Expires as well, BUT you are using ZERO. You need to change this to -1. Full explanation here:

HTTP Expires header values "0" and "-1"

stldoug
  • 853
  • 9
  • 14