温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

php header cache

发布时间:2020-05-31 06:52:45 来源:网络 阅读:384 作者:here2142 栏目:web开发

php header()中的cache有四种标识头:Last-Modified,Expires,Pragma: no-cache,Cache-Control。

以下的测试环境为谷歌浏览器,其余的未测试

  1. Last-Modified:在判断缓存的时候,If-Modified-Since会将此值发送给服务器

  2. Expires:后面的日期用于标识缓存在什么时候过期

  3. Pragma:尽量用Cache-Control替代

  4. Cache-Control:可以有如下的值:

    1. public:可以在任何地方缓存,包括浏览器、代理等

    2. private:只能被浏览器缓存,共享缓存不可被缓存

    3. no-cache:不缓存

    4. no-store:

    5. no-transform:

    6. must-revalidate:缓存必须检查更新版本

    7. proxy-revalidate:代理缓存必须检查更新版本

    8. max-age:内容能够被缓存的时期,以秒表示

    9. s-maxage:覆盖共享缓存的max-age设置

下面看看Last-Modified

1.php

<?php
$cache_expire_date = gmdate("D, d M Y H:i:s", time() + 300);
header("Last-Modified:$cache_expire_date");
?>
<a href="2.php" title="">this is page 1</a>
<div>
    page 1 number:111
</div>

2.php

<?php
?>
<a href="1.php" title="">this is page2</a>
<div>
    page 2 number:
</div>

当点击链接或者刷新1.php的时候,会发现其RequestHeaders中多了一行If-Modified-Since字段。但是,单独的Last-Modified不会有任何的缓存作用。


下面来看看Expires:

将1.php修改

<?php
$cache_expire_date = gmdate("D, d M Y H:i:s", time() + 300);
header("Expires: $cache_expire_date");
?>
<a href="2.php" title="">this is page 1</a>
<div>
    page 1 number:111
</div>

第一次请求1.php的时候,和普通的无差别

在2.php中跳转回1.php,发现Network--Size中显示的是from cache,而且点击文件,其Headers一栏也没有RequestHeaders等信息。它直接从缓存中获取。此时即使将div中的数字修改,在300秒以内,通过2.php链接跳转回来,依然显示的是未修改前的页面。

但是刷新页面以后,请求和普通的也无差别。


接下来看看Cache-control

将1.php修改为

<?php
header('Cache-control:private,');
?>
<a href="2.php" title="">this is page 1</a>
<div>
    page 1 number:111
</div>

对于没有设置时间的Cache-control,和普通的无差别

接下来继续修改

<?php
header('Cache-control:private, max-age=300');
?>
<a href="2.php" title="">this is page 1</a>
<div>
    page 1 number:111
</div>

这个和通过Expires设置的差不多。

当页面为

<?php
header('Cache-control: max-age=300');
?>
<a href="2.php" title="">this is page 1</a>
<div>
    page 1 number:111
</div>

即使不设置private参数,也会缓存

当参数为no-cache的时候,均会重新请求


向AI问一下细节

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

AI