Laravel 4 应用程序中的浏览器缓存问题

2023-12-21

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

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

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

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

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

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

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

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


EDIT:

惊喜,惊喜 - 之前的解决方案在 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 调用。这个问题 https://stackoverflow.com/questions/168963/stop-jquery-load-response-from-being-cached提供了一些非常有用的答案。

以下内容在 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');
});

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

的答案这个问题 https://stackoverflow.com/questions/17548569/where-can-i-set-headers-in-laravel提供了一些非常有用的信息。

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

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

Laravel 4 应用程序中的浏览器缓存问题 的相关文章