【问题标题】:Browser Cache issues in Laravel 4 ApplicationLaravel 4 应用程序中的浏览器缓存问题
【发布时间】:2013-10-01 12:06:08
【问题描述】:

浏览器缓存干扰我的 Laravel 应用程序时遇到问题。

如果禁用浏览器缓存,一切正常。但是,如果启用,并且重复单击相同的链接,则创建视图或收集数据的 Laravel 方法甚至都不会执行。

含义是多方面的。例如,用于编辑资源的表单或显示数据的网格(使用 ajax 从服务器加载),在重新加载浏览器之前不会显示当前值。

我在一些记录当前时间戳的方法中添加了一行来证明这一点。

public function index()
{
    Log::info( microtime() );

    return View::make( $this->templates_root . 'index' );
}

当重复单击链接或再次访问视图时,日志中不会出现任何行。但如果我重新加载浏览器,它会这样做。

如何防止浏览器缓存我的视图?

【问题讨论】:

标签: php caching laravel laravel-4 browser-cache


【解决方案1】:

编辑:

惊喜,惊喜 - 以前的解决方案在 IE 中不起作用。

又花了几个小时后,我最终将以下内容添加到 blade 模板标题中:

<meta http-equiv="cache-control" content="max-age=0" />
<meta http-equiv="cache-control" content="no-cache" />
<meta http-equiv="cache-control" content="no-store" />
<meta http-equiv="cache-control" content="must-revalidate" />
<meta http-equiv="expires" content="0" />
<meta http-equiv="expires" content="Tue, 01 Jan 1980 1:00:00 GMT" />
<meta http-equiv="pragma" content="no-cache" />

这似乎适用于所有浏览器。

此外,我必须防止缓存所有 AJAX 调用。 This question 提供了一些非常有用的答案。

以下内容在 IE 中不起作用:

我找到了一个解决方案 - 在我看来不是一个漂亮的解决方案。

如下使用(全局后)过滤器...

App::after(function($request, $response)
{
    // prevent browser caching
    $response->headers->set('Cache-Control','nocache, no-store, max-age=0, must-revalidate');
    $response->headers->set('Pragma','no-cache');
    $response->headers->set('Expires','Fri, 01 Jan 1990 00:00:00 GMT');
});

似乎强制浏览器从服务器重新加载页面。

this question 的答案提供了一些非常有用的信息。

但是,我仍然想知道为什么其他开发人员没有同样的问题,或者如果他们有,他们是如何解决的。

【讨论】:

  • 我也试过这个解决方案,但它不是最好的。当您使用提到的标题时,您会在加载之间在 chrome 中看到白色闪烁。
猜你喜欢
  • 2013-09-27
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 2014-05-22
  • 1970-01-01
  • 2010-10-31
  • 2015-03-02
相关资源
最近更新 更多