How to force a web browser to cache Images

2019-01-11 06:41发布

问题:

I am writing a small application which serves images from the local computer, so they can be accessed as http://localhost:12345/something/something (which returns a jpeg).

How can I force the browser to cache this, so only a single request would be sent to the server. Would this header be sufficient

HTTP/1.1 200 OK
Cache-Control: public, max-age=99936000
Content-Length: 123456
Content-Type: image/jpeg

This seems to work with Firefox 3.x but would it be sufficient globally for other browser as well?

回答1:

A Last-Modified and Expires header might also be useful additions.

Your server should also check for requests featuring an If-Modified-Since header, and return a 304 Not Modified response if possible to speed things along.



回答2:

try the expires http header: http://en.wikipedia.org/wiki/List_of_HTTP_headers

You probably have to merge this with your cache-control



回答3:

You can't and nor should you - this is the user's decision to make not yours.

What you can do is strongly suggest with the right headers, but even then you should expect t deal with a number of HEAD requests ever after.