Reputation: 25151
Is there any way to disable this 'feature'?
For example, if a request is made to http://localhost/foo.html
that I have specified to '301' to the root address, all subsequent requests to foo.html
bypass the web server completely and ffox 5 will check it's cache, read that this url was '301'ed previously and redirect without even checking for a change.
If i have stopped foo.html
from 301'ing, I have to clear firefox's cache in order to 'fix' this from happening.
Chrome, IE and previous version of Firefox do not do this.
Upvotes: 98
Views: 41701
Reputation: 1874
In Firefox you have the "Web Developer" Tools (Ctrl+Shift+I). You can click "Network" tab and check the checkbox "Disable Cache" to check for new version of page every time. Then load the original URL and it will refresh your cache. Then you can enable the cache again and access that URL also from other tabs. So you don't need to clear your full cache.
From cptstubing06's comment, the following can help clear the cache:
about:config
to open the configuration settings.browser.cache
followed by Enter to filter the settings.browser.cache.check_doc_frequency
.3
to 1
.OK
.Firefox should now redirect to the new 301 page, no longer fetching the redirected page from cache.
Upvotes: 140
Reputation: 9266
The developer tools built into recent versions of Firefox has a solution for this. First, turn off caching when the dev pane is open:
Advanced Settings
check the option Disable Cache (when toolbox is open)
Now any time you want to force a refresh of a cached page, load/refresh the page with the F12 dev toolbox open. Firefox will bypass the cache and get fresh data from the server.
I prefer this method because it doesn't change how the browser behaves for "normal" non-debug browsing, and you don't risk forgetting to restore a global setting to its original value.
Verified in Firefox 39
Upvotes: 6
Reputation: 786
In Firefox Version 38.0
Menu -> Edit -> Preferences -> Advanced -> Network -> Clear Now
Worked for me.
Upvotes: 2
Reputation: 35074
301 is just a normal cacheable response code. http://www.w3.org/Protocols/rfc2616/rfc2616-sec10.html#sec10.3.2 says:
This response is cacheable unless indicated otherwise.
So if you don't want it cached, your server needs to indicate otherwise through the normal headers used to control cache behavior.
You can also clear the cache manually.
Upvotes: 42
Reputation: 27330
I have found a solution for this that works on Firefox 26, after having an obsolete redirect cached for over a month and a restart.
All cached pages, images and redirects for only that site will be removed from the cache. This lets you clear the redirect for your development website without clearing the rest of your cache.
As a side note, I think Firefox should only cache redirects for a few days at most. Caching them for over a month can make a simple mistake a big problem.
Upvotes: 10
Reputation: 1204
I just experienced this problem, and for me it was two issues.
This particular domain name is routed through Cloudflare, so I had to set it to development mode. I think Cloudflare was caching the 301 redirect so it didn't have to send the request to the server. This step might not apply to you obviously.
Then, I simply cleared my Firefox cache (version 11) by going to Tools -> Options, clicking the Advanced button at the upper right, selecting the Network tab, and then clicking Clear Now under the section Cached Web Content. Note my cache was already set to 0, but I still needed to click the Clear Now button to get the redirect to stop being cached.
I'd be interested to know if anyone else can verify this.
Upvotes: 25
Reputation: 1397
301 means Moved Permanently and is cachable, so I think that's the "right" behavior for the browser. You should use 303 See Other.
Upvotes: 1
Reputation: 19832
A 301 indicates moved permanently. Therefore I see it to be reasonable to cache the response.
Have you tried setting the cache-control
and expires
headers?
http://www.w3.org/Protocols/rfc2616/rfc2616-sec14.html#sec14.9
Upvotes: 3