按下后退按钮时如何使Firefox重新加载页面?

时间:2011-01-07 21:30:07

标签: php javascript html firefox back-button

我尝试过阻止页面缓存的元标记的每个组合和排列,但Firefox STILL会缓存页面! 当用户按下后退按钮时,我只需要重新加载URL。在IE8中正常工作。

我已经尝试了所有这些......

<meta http-equiv="Cache-Control" content="no-store" />
<meta http-equiv="Pragma" content="no-cache"/>
<meta http-equiv="Expires" content="-1"/>
<meta http-equiv="Expires" content="Sat, 1 Jan 2000 00:00:00 GMT" /> 

...我也尝试过以下JavaScript ......

<input type="hidden" id="refreshed" value="no"/>
<script type="text/javascript">

    onload=function(){
        var e=document.getElementById("refreshed");
        if(e.value=="no"){
            e.value="yes";
        }

        else{
            e.value="no";
            location.reload();
        }

    }

</script> 

......一切都无济于事。我在这里错过了什么?如果重要的话,页面是用PHP生成的。

更新1:

到目前为止,我已经尝试了所有建议,但我仍然无法让它发挥作用。当我使用Chris的PHP代码时,我就像这样使用它......

<?php
header("Cache-Control: no-store, no-cache, must-revalidate, max-age=0");
header("Expires: Sat, 26 Jul 1997 05:00:00 GMT");
?>
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html dir="ltr" xmlns="http://www.w3.org/1999/xhtml">
<!--the rest of my page-->

..正如您所见,它位于我网页的EXTREME顶部,位于DOCTYPE标题之前。

我也尝试了session_start(),但即使阅读了手册,我也不确定我是否正确使用它。我也把它放在我页面的最顶端。

我愿意接受任何建议,这些建议可以在不破坏其他页面功能的情况下完成。我知道我已经看过每次使用后退按钮重新加载的页面,它们是如何做的?!

解决!

事实证明我有多个问题对我不利,但通过尽职调查,我能够消除这些问题并取得胜利。

Chris将他的代码更新为......

<?php
header("Cache-Control: no-store, no-cache, must-revalidate, max-age=0");
header("Expires: Sat, 26 Jul 1997 05:00:00 GMT");
echo time();
?><a href="http://google.com">aaaaaaaaaaaaa</a>

我发现他的代码确实在我使用它时确实有效,但是当我把它放到我的页面时它没有用。我的所有页面都是.php.html,所有页面都附加到DWT(动态Web模板),因此我使用Chris的代码一次更新所有页面。我没有意识到DWT在DOCTYPE标题之后开始正确,因此代码从未插入到我的页面中。我找不到让DWT包含DOCTYPE标题的方法,所以我进入了所有页面并手动将代码插入DOCTYPE标题上方。

接下来我发现,即使我的服务器设置为将.htm.html解析为.php.html页面也会在我插入的位置生成错误克里斯的代码说“无法修改标题,标题已经发送”的效果。我并不关心我的扩展程序是什么,所以我只是将所有.html扩展程序更改为.php扩展程序。

最后一个小麻烦是,即使页面现在没有被缓存(就像我想要的那样),当用户使用后退按钮时(即如果用户在哪里),Firefox将用户放在上一页的最后位置页面底部a当他们导航到页面b时,然后用户使用页面b上的后退按钮,它们将返回到页面a的底部,而不是页面顶部的a)。修剪我原来的JavaScript修复了这个......

    <script type="text/javascript">

        onload=function(){
            document.getElementById('content').scrollTop=0;
        }

    </script>

即使这对于这样一个简单的问题似乎非常复杂,但我很高兴它得到修复。感谢大家的帮助(尤其是克里斯)。

7 个答案:

答案 0 :(得分:9)

这对我有用

制作一个新的php文件。我可以使用后退和前进按钮,页面上的数字始终更新

<?php
header("Cache-Control: no-store, no-cache, must-revalidate, max-age=0");
header("Expires: Sat, 26 Jul 1997 05:00:00 GMT");
echo time();
?><a href="http://google.com">aaaaaaaaaaaaa</a>

答案 1 :(得分:3)

您可以在PHP页面中添加以下PHP代码。

CodeIgniter Framework version:
$this->output->set_header('Last-Modified:'.gmdate('D, d M Y H:i:s').'GMT');
$this->output->set_header('Cache-Control: no-store, no-cache, must-revalidate');
$this->output->set_header('Cache-Control: post-check=0, pre-check=0',false);
$this->output->set_header('Pragma: no-cache');

PHP版本:

header('Last-Modified:'.gmdate('D, d M Y H:i:s').'GMT');
header('Cache-Control: no-store, no-cache, must-revalidate');
header('Cache-Control: post-check=0, pre-check=0',false);
header('Pragma: no-cache');

您还可以在<head>部分的

中的登录/母版页面中添加以下Java脚本代码
<script language="javascript" type="text/javascript">
    window.history.forward();
</script>

中验证了兼容性
  • Internet Explorer
  • Google Chrome
  • Mozilla Firefox
  • Opera

答案 2 :(得分:0)

查看实时http标头,当您按下后退按钮时,您将看到没有请求。这是故意的,所以你不要放弃你在表格中输入的内容。

修改

一些关于专家交流的帖子说这很有效,但是从2006年开始。

<META HTTP-EQUIV="Expires" CONTENT="0">
<META HTTP-EQUIV="Pragma" CONTENT="no-cache">
<META HTTP-EQUIV="Cache-Control" CONTENT="no-cache">
<META HTTP-EQUIV="Cache-Control" CONTENT="no-store">

然后刷新javascript

答案 3 :(得分:0)

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

我认为正确的值是“no-cache”

答案 4 :(得分:0)

session_cache_limiter('nocache');

这应该会自动生成所有必需的标题。请注意,某些浏览器(如Opera)在使用后退按钮时仍会忽略这些。

修改

相关标题如下,如果您想以其他方式生成它们:

Expires: Thu, 19 Nov 1981 08:52:00 GMT
Cache-Control: no-store, no-cache, must-revalidate, post-check=0, pre-check=0
Pragma: no-cache

答案 5 :(得分:0)

为什么呢? 我的意思是,你为什么要这样做? 当我按下后退按钮时,我想要浏览器提供的标准功能 - 返回上一页。我不想要一个惊喜。

如果要停止意外重新提交POST,可以通过使用重定向结束POST处理以使用GET显示所需的回复来轻松完成。稍后回到此页面,将重新显示重定向的GET(或从缓存重新加载它必须具有相同的结果)。这是用户期望的并且是无害的。

这具有额外的优势,如果在更新数据库时保存失败,显示将显示数据库上的内容,而不是变量中剩余的内容。

答案 6 :(得分:0)

您发表了评论:

  

这是因为一旦表格已经存在   提交,如果用户按下   后退按钮,它们是什么信息   观看将是不准确的。

如果你想要防止这种情况你做错了! :)

您需要做的是在提交表单时进行重定向。

<?php
    // code that handles the form submit
    header("Location: http://www.example.com/form-success.html"); // needs the absolute url (You can use $_SERVER['HTTP_HOST'], $_SERVER['PHP_SELF'] and dirname() for this)
    exit; // prevents further execution of the php code when while doing to redirect
?>