• Status: Solved
  • Priority: Medium
  • Security: Public
  • Views: 468
  • Last Modified:

Avoiding IE Browser Cache

I have a program that makes HTTP based requests for a file from our IIS server.  The file is a text file that contains a number representing the current version.  My program reads the version number and compares it to program's version number to determine if there is an upgrade available.

One of our customers experienced a problem whereby the file is not read from our web server, but instead from their browser's (IE) cache.  

When observing the network with a packet sniffer, it was found that the application on Windows Terminal Server 2003 was checking its IE cache, then formulating the request using the If-Modified-Since header.    A windows XP station is using the Unless-Modified-Since header.  These two headers process in different ways on IIS server.  If I recall correctly, the former was not returning results from the server unless the .txt file date on the server has a modify date greater than the expected date.   The latter will return the file if the date is greater than or equal to the current date.  This generally allows for Windows XP stations to download the file even if it hasn’t necessarily been changed – which appears to be one reason that most people with my software are not typically affected by this.  

Additionally, there are times when the IE cache is handing back an older copy of the file.

One work-around has been to clear the IE cache before having the program do an update check.  This works like a charm.  However, I cannot have every customer that determines they are experiencing this problem clear the IE cache every time they go to do an update.

Ideally, I would like to have the calls to WinInet.InternetOpen() flagged so that they never pull from the browser cache.  However, I do not see in the documentation (http://msdn.microsoft.com/en-us/library/aa385096%28v=vs.85%29.aspx) where it gives me an option for this.  I’m using a  0x0 for the dword dwFLAGS entry currently.

Does anybody have any ideas on how I can make my calls so that the browser cache is never referenced?  The documentation provides for making calls specifically to use the cache only, but I don’t see where I have the option to never use the cache.

0
efz
Asked:
efz
2 Solutions
 
sjklein42Commented:
In your program, append "?v=nnnnn" to the URL for the text file, where nnnnn is a random number you generate each time you fetch the file.

This will force it to be loaded fresh from your server, since the URL is different each time.

So instead of fetching

www.yourdomain.com/version.txt

you fetch

www.yourdomain.com/version.txt?v=452746 (for example)

The "CGI" arguments do not affect the fetching of the text file, just the caching.
0
 
Dave BaldwinFixer of ProblemsCommented:
Here's the Microsoft page about preventing browser caching: http://support.microsoft.com/kb/234067  @sjklein42's idea is a good one also.  In PHP, we frequently use the Unix time stamp as the query string value because people seldom request the page more than once in a second.
0
 
efzAuthor Commented:
Sorry for the brief delay in getting back to you. Please accept my sincere thanks for your excellent efforts.
0
Question has a verified solution.

Are you are experiencing a similar issue? Get a personalized answer when you ask a related question.

Have a better answer? Share it in a comment.

Join & Write a Comment

Featured Post

Free Tool: Port Scanner

Check which ports are open to the outside world. Helps make sure that your firewall rules are working as intended.

One of a set of tools we are providing to everyone as a way of saying thank you for being a part of the community.

Tackle projects and never again get stuck behind a technical roadblock.
Join Now