Search code examples
httpcachingrequestresponse

if-modified-since vs if-none-match


What could be the difference between if-modified-since and if-none-match? I have a feeling that if-none-match is used for files whereas if-modified-since is used for pages?


Solution

  • Regarding the differences between Last-Modified/If-Modified-Since and ETag/If-None-Match:

    Both can be used interchangeably. However depending on the type of resource, and how it is generated on the server, one or the other question ("has this been modified since ...?" / "does this still match this ETag?") may be easier to answer.

    Examples:

    • If you're serving files, using the file's mtime as the Last-Modified date is the simplest solution.
    • If you're serving a dynamic web page built from a number of SQL queries, checking whether the data returned by any of those queries has changed may be impractical (unless all of them have some sort of "last modified" column). In this case, using e.g. an md5 hash of the page content as the ETag will be a lot easier.
      OTOH, this means that you still have to generate the whole page on the server, even for a conditional GET. Figuring out what exactly has to go into the ETag (primary keys, revision numbers, ... etc.) can save you a lot of time here.

    See these links for more details on the topic: