我正在调试一个HTTP 301永久重定向的问题。经过快速测试,Safari似乎在重新启动时清除了它的301缓存,但Firefox却没有。

IE、Chrome、Firefox和Safari什么时候清空它们的301缓存?

For example, if I want to redirect 1.example to 2.example, but I accidentally set it to redirect to 3.example, that is a problem. I can correct the mistake, but anyone who has visited 1.example in the meantime will have cached the incorrect redirect to 3.example, and so they will not be able to reach either 1.example or 2.example until their cache is cleared. Upon investigation, I find that there were no Cache-Control and Expires headers set. The headers for the incorrect 301 response would have been like this:

HTTP/1.1 301 Moved Permanently
Date: Wed, 27 Feb 2013 12:05:53 GMT
Server: Apache/2.2.21 (Unix) DAV/2 PHP/5.3.8
X-Powered-By: PHP/5.3.8
Location: http://3.example/
Content-Type: text/html

我自己的测试表明:

IE7, IE8, Android 2.3.4完全不缓存。 Firefox 18.0.2、Safari 5.1.7(适用于Windows 7)和Opera 12.14都有缓存,并在重新启动浏览器时清除缓存。 IE10和Chrome 25缓存,但不清楚浏览器重启,所以他们什么时候会清除?


301是每个HTTP RFC的可缓存响应,浏览器将根据响应上的HTTP缓存头缓存它。使用FireBug或Charles检查响应头,以了解响应将被缓存的确切时间。

如果你想控制缓存持续时间,你可以使用HTTP响应头Cache-Control和Expires来做同样的事情。或者,如果根本不想缓存301响应,可以使用下面的头文件。

Cache-Control: no-store, no-cache, must-revalidate
Expires: Thu, 01 Jan 1970 00:00:00 GMT

在没有指定其他缓存控制指令的情况下,301重定向默认为不带任何过期日期的缓存。

也就是说,只要浏览器的缓存可以容纳它,它就会一直被缓存。如果您手动清除缓存,或者为了给新缓存腾出空间而清除缓存条目,则会将其从缓存中删除。

您至少可以在Firefox中通过about:cache并在磁盘缓存下找到它来验证这一点。它在包括Chrome和基于Chromium的Edge在内的其他浏览器中也是这样工作的,尽管它们没有about:cache来检查缓存。

在所有浏览器中,仍然可以使用缓存指令覆盖这个默认行为,如下所述:

如果你不希望重定向被缓存

这种不确定缓存只是这些浏览器在没有指定的头文件时的默认缓存。逻辑是你指定了一个“永久的”重定向,而不给他们任何其他缓存指令,所以他们会把它当作你想要无限缓存。

如果指定了Cache-Control和Expires头,浏览器仍然像其他响应一样尊重它们。

您可以添加诸如Cache-Control: max-age=3600或Expires: Thu, 01 Dec 2014 16:00:00 GMT到您的301重定向头。你甚至可以添加Cache-Control: no-cache,这样它就不会被浏览器永久缓存,或者Cache-Control: no-store,这样它甚至不能被浏览器存储在临时存储中。

但是,如果您不希望您的重定向是永久的,那么使用302或307重定向可能是更好的选择。发出一个301重定向,但将其标记为不可缓存违背了301重定向的精神,即使它在技术上是有效的。YMMV,您可能会发现一些边缘情况,其中“永久”重定向具有时间限制是有意义的。注意,302和307重定向在浏览器默认情况下不缓存。

如果您之前发出了301重定向,但想要取消该操作

如果人们在浏览器中仍然有缓存的301重定向,他们将继续被带到目标页面,而不管源页面是否仍然有重定向。解决这个问题的方法包括:

A simple solution is to issue another redirect back again. If the browser is directed back to a same URL a second time during a redirect, it should fetch it from the origin again instead of redirecting again from cache, in an attempt to avoid a redirect loop. Comments on this answer indicate this now works in all major browsers - but there may be some minor browsers where it doesn't. If you don't have control over the site where the previous redirect target went to, then you are out of luck. Try and beg the site owner to redirect back to you.

预防胜于治疗-避免301重定向,如果你不确定你想要永久撤销旧的URL。


一个帮助那些迫切想摆脱重定向缓存的人的答案:

Chrome无限缓存301重定向(在本地磁盘缓存中)。清除缓存。

打开你的开发工具(按F12) 在“网络”选项卡上选中“禁用缓存”复选框 保持DevTools打开并重新加载页面(按F5)

当一切正常时,您可以取消“禁用缓存”,一切将继续按预期工作。


我有一个简单的解决方案,适用于所有主要的浏览器(最新版本),包括IE, Chrome和FF

Ctrl + Shift + Del - Chrome浏览器:选择“浏览历史记录”和“缓存…” IE:我离开默认选项“临时互联网文件和网站文件”,“Cookies和网站数据”,“历史” FF:“浏览和下载历史”,“缓存” 点击“删除” 关闭并重新打开浏览器。应该可以


为了测试目的(避免缓存重定向),人们可以打开NEW PRIVATE WINDOW:点击CTRL+SHIFT+N[如果你使用Mozilla,使用P]


Chrome 71

要清除永久重定向,转到chrome://settings/clearBrowserData,从那里只清除“缓存的图像和文件”清除重定向。

Chrome 48 - 70

转到chrome://net-internals。在顶部红色状态栏右侧,点击向下箭头▼打开下拉菜单,在“工具”组下,选择“清空缓存”。

在48版中,这是唯一对我有效的清除缓存301的方法。


作为@thomasrutter的回答

如果您之前发出了301重定向,但想要取消该操作

如果人们在浏览器中仍然有缓存的301重定向,他们将继续被带到目标页面,而不管源页面是否仍然有重定向。解决这个问题的方法包括:

最简单和最好的解决方案是再次发出301重定向。

浏览器会意识到它被引导回到它之前认为是退役的URL,这应该会导致它重新获取该URL,以确认旧的重定向不存在。

如果您无法控制前一个重定向目标所访问的站点,那么您就不走运了。试着请求网站所有者重定向回你。

事实上,这意味着:

a. 301到b.example 删除a.example的301 将b.example 301添加到a.example中

这样就有用了。


让用户在该url上提交一个post表单,缓存的重定向消失了:)

<body onload="document.forms[0].submit()">
<form action="https://forum.pirati.cz/unreadposts.html" method="post">
    <input type="submit" value="fix" />
</form>
</body>

使用隐身/InPrivate模式测试重定向,这样当你关闭浏览器时,它会刷新缓存,重新打开窗口时将不包含缓存。


正如其他答案所示,在浏览器中缓存的持续时间可能是无限的。这是极其危险和恼人的。所以不要这么做。至少添加缓存头。在htaccess中,我总是这样做,根本没有缓存:

<IfModule mod_rewrite.c>
  RewriteCond %{HTTP_HOST} ^(www\.)?example\.com$ [NC]
  # The E=nocache:1 sets the environment variable nocache to the value of one
  RewriteRule ^/?(.*) https://www.example.org/$1 [L,R=301,E=nocache:1]
</IfModule>


<IfModule mod_headers.c>
  ## Set the response header if the "nocache" environment variable is set
  ## in the RewriteRule above.
  Header always set Cache-Control "no-store, no-cache, must-revalidate" env=nocache

  ## Set Expires too ...
  Header always set Expires "Thu, 01 Jan 1970 00:00:00 GMT" env=nocache
</IfModule>

编辑:

如果过去没有缓存301重定向,则必须从目标重定向回源。例子:

如果你有这个

RewriteRule /my-source /my-target [L,R=301]

你需要把这个

# RewriteRule /my-source /my-target [L,R=301]
RewriteRule /my-target /my-source [L,R=301]

确认! !让用户向受影响的url提交post请求,缓存的重定向将被遗忘。

一个快速的取胜方法是在浏览器控制台输入这个:

fetch (example.com/affected/link,{方法:“post”})不要犹豫 (() => {})

如果您了解受影响的浏览器(特别是在开发过程中),则非常有用。

或者,如果您可以访问之前的301重定向页面,那么您可以将此脚本添加到页面中,无论何时访问它,缓存的301都将被遗忘。


有一个非常简单的方法来删除浏览器缓存http重定向,如301,307等。

你可以在chrome浏览器的开发控制台打开网络面板。选择网络调用。右键单击它,然后单击“清除浏览器缓存”以删除缓存的重定向。


为了解决localhost地址的问题,我更改了站点运行的端口号。这适用于Chrome版本73.0.3683.86。


我将发布帮助我的答案:

转到url:

chrome://settings/clearBrowserData

它应该调用弹出窗口,然后..

仅选择:缓存的图像和文件。 选择时间框:从开始


在最新的谷歌Chrome版本79上,可以使用Chrome://net-internals 并从左侧面板选择DNS,然后点击清除主机缓存按钮


在你的。htaccess文件中试试这个:

  <IfModule mod_expires.c>
  ExpiresActive On
  Header set Cache-Control "no-store, no-cache, must-revalidate, max-age=0"
  Header Set Cache-Control "max-age=0, no-store"
  Header Set Cache-Control "no-store"
  Header set Pragma "no-cache"
  </IfModule>

移动Chrome(93版)的一个技巧:尝试在“桌面网站”模式下打开url -这在我的情况下删除了一个永久缓存重定向。


要禁用重定向,请将此代码放在重定向站点的索引文件中

<script>
    fetch('https://www.example.com', {method: 'post'}).then(() => {})
</script>