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.