Question

We have implemented a popup window as a modal dialog using the IE method:

window.showModalDialog('...aspx')

The target of the popup window is itself an ASP.Net web page.

Assume for the following steps that the popup has never been launched:

  1. Launch popup.
  2. Page_Load event handler executes on server side.
  3. Close popup.
  4. Immediately launch popup again.
  5. This time Page_Load event handler doesn't execute.

It's clear that the popup content is being cached because if at Step 4 we clear the temporary internet files the Page_Load event handler is executed the second time.

We have experimented with adding the following to the Head of the web page (as recommended by several other sources) but none of it seems to work.

<meta http-equiv="Cache-Control" content="no-cache" />
<meta http-equiv="Pragma" content="no-cache" />
<meta http-equiv="Expires" content="-1" />

We have also seen places where the use of these is discouraged

Can anyone help?

Was it helpful?

Solution

Add a timestamp querystring variable to the URL of the dialog content - number of ticks since 1/1/08 or something - IE will treat it as a new page and ignore the cache.

OTHER TIPS

To clear cache add this in page load:

Response.Cache.SetCacheability(HttpCacheability.NoCache);

Given that the http-equiv directives don’t work (and arguably shouldn’t be used), and despite it unfortunately being in the hack category of solutions, I think we are going to have to go with this (posted by Greg)...

url = "<Some url with query string>"
var date = new Date();
window.showModalDialog(url + “&” + date.getTime(), ... );

It is strange that there is no definitive way to disable caching on these modal dialogs. I’m not sure whether using modal dialogs in web browsers is accepted as a "good idea" or not, but we are aware of at least some of the shortcomings and alternatives, but are just unfortunately unable to use them in this project.

Thanks for your suggestions.

Place Fiddler in between the IE and your server. Then check if the response to your request carries a HTTP header Cache-Control. Is there some value given other than no-cache ? If so then maybe IE will give this header priority over your http-equiv directive.

If not, you should try to make the server send the HTTP header Cache-Control:no-cache. If IE does not respect this, it's a bug in IE. Experience shows it's less painfull to opt for a different solution than to press for a bugfix, so in this case I'd agree to the tip of Greg.

First i tried by using the following code.

meta http-equiv="Cache-Control" content="no-cache" 
meta http-equiv="Pragma" content="no-cache" 
meta http-equiv="Expires" content="-1" 

but it was not given any solution after, i tried with Query String with time stamp variable, like

vat time = new Date().getTime();

url?queryString&time=time

then it works....

Thanks...

you forgot a tag to reprocess the page.

<base target="_top" />

if you put below tags, the cache will be cleaned:

<meta http-equiv="Expires" content="0" />
<meta http-equiv="Cache-Control" content="no-cache, must-revalidate" />
<meta http-equiv="Pragma" content="no-cache" />
<base target="_top" />

One of the strange quirks of IE is that setting no-cache at the beginning of the file doesn't seem to work, but moving that section to after the original HTML often does. Still best to send it as an HTTP header, but the following will work in most cases:

<html>
   <head><title>Blah</title></head>
   <body>Contents</body>
</html>
<html>
   <head>
      <meta http-equiv="Cache-Control" content="no-cache" />
      <meta http-equiv="Pragma" content="no-cache" />
      <meta http-equiv="Expires" content="-1" />
   </head>
</html>

The answer Response.Cache.SetCacheability(HttpCacheability.NoCache); is the only one that works correctly with IE9. If you set the timestamp in the querystring, you still have to refresh the page to get a different URL. So, the modal dialog is still cached until the page is refresh, unless you use Response.Cache.SetCacheability(HttpCacheability.NoCache); Using a timestamp on the URL and Response.Cache.SetCacheability(HttpCacheability.NoCache); would be best, cover all the bases. It is IE we're dealing with after all.

You could also try the following statement at the top of the aspx page being called:

<%@ OutputCache Location="None" %>
Licensed under: CC-BY-SA with attribution
Not affiliated with StackOverflow
scroll top