Solved

Avoiding IE Browser Cache

Posted on 2011-03-15
3
460 Views
Last Modified: 2012-06-22
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
Comment
Question by:efz
3 Comments
 
LVL 16

Accepted Solution

by:
sjklein42 earned 250 total points
ID: 35140138
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
 
LVL 83

Assisted Solution

by:Dave Baldwin
Dave Baldwin earned 250 total points
ID: 35140214
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
 

Author Closing Comment

by:efz
ID: 35166353
Sorry for the brief delay in getting back to you. Please accept my sincere thanks for your excellent efforts.
0

Featured Post

PRTG Network Monitor: Intuitive Network Monitoring

Network Monitoring is essential to ensure that computer systems and network devices are running. Use PRTG to monitor LANs, servers, websites, applications and devices, bandwidth, virtual environments, remote systems, IoT, and many more. PRTG is easy to set up & use.

Question has a verified solution.

If you are experiencing a similar issue, please ask a related question

Running classic asp applications under Windows Server 2008 R2 (x64) and IIS 7 is not as easy as one may think. It took me a while to figure it out while getting error 8002801d a few times. After you install the OS you will need to install the fol…
Prologue It is often required to host multiple websites on a single instance of IIS, mostly in development environments instead of on production servers. I am sure it is not much a preferred solution on production servers but this is at least a pos…
With Secure Portal Encryption, the recipient is sent a link to their email address directing them to the email laundry delivery page. From there, the recipient will be required to enter a user name and password to enter the page. Once the recipient …
The Email Laundry PDF encryption service allows companies to send confidential encrypted  emails to anybody. The PDF document can also contain attachments that are embedded in the encrypted PDF. The password is randomly generated by The Email Laundr…

828 members asked questions and received personalized solutions in the past 7 days.

Join the community of 500,000 technology professionals and ask your questions.

Join & Ask a Question