PHP下利用header()函数设置浏览器缓存的代码 这涉及到4种头标类型: Last-Modified(最后修改时间); Expires(有效期限); Pragma(编译指示): Cache-Control(缓存控制); 前三个头标属于HTTP1.0标准.头标Last-Modified使用UTC日期时间值.如果缓存系统发现Last-Modified值比页面
这涉及到4种头标类型:
Last-Modified(最后修改时间);
Expires(有效期限);
Pragma(编译指示);
Cache-Control(缓存控制);
前三个头标属于HTTP1.0标准。头标Last-Modified使用UTC日期时间值。如果缓存系统发现Last-Modified值比页面缓存版本的更接
近当前时间,他就知道应该使用来自服务器的新版本。
Expires 表明了缓存版本何时应该过期(格林威治标准时间)。把它设置为一个以前的时间就会强制使用服务器上的页面。
Pragma生命了页面数据应该如何被处理。可以这样避免对页面进行缓存:
header("Pragma:no-cache");
Cache-Co0ntrol 头标是在HTTP1.1里添加的,能够实现更细致的控制(还应该继续使用HTTP1.0头标)。Cache-Control的设置有
很多,如下表:
| 指令 | 含义 |
| public | 可以在任何地方缓存 |
| private | 只能被浏览器缓存 |
| no-cache | 不能在任何地方缓存 |
| must-revalidate | 缓存必须检查更新版本 |
| proxy-revalidate | 代理缓存必须检查更新版本 |
| max-age | 内容能够被缓存的时期,以秒表示 |
| s-maxage | 覆盖共享缓存的max-age设置 |
代码如下:
<?php # Script 2.7 - view_tasks.php
// Connect to the database:
$dbc = @mysqli_connect ('localhost', 'username', 'password', 'test') OR die ('<p>Could not connect to the database!</p></body></html>');
// Get the latest dates as timestamps:
$q = 'SELECT UNIX_TIMESTAMP(MAX(date_added)), UNIX_TIMESTAMP(MAX(date_completed)) FROM tasks';
$r = mysqli_query($dbc, $q);
list($max_a, $max_c) = mysqli_fetch_array($r, MYSQLI_NUM);
// Determine the greater timestamp:
$max = ($max_a > $max_c) ? $max_a : $max_c;
// Create a cache interval in seconds:
$interval = 60 * 60 * 6; // 6 hours
// Send the header:
header ("Last-Modified: " . gmdate ('r', $max));
header ("Expires: " . gmdate ("r", ($max + $interval)));
header ("Cache-Control: max-age=$interval");
?>
1.连接数据库后获取数据表中最新的日期值date_added,date_completed,用UNIX_TIMESTAMP()函数将返回值转化为整数然后获取最大值赋予$max。
2.定义一个合理缓存时间。
代码如下:
$interval=60*60*6
合理值屈居于页面本身、访问者的数量和页面的更新频率,以上代码为6个小时。
3.发送Last-Modified头标。
代码如下:
header("Last-Modified:".gmdate("r",($max+$interval)));
gmdate()函数使用了参数"r"时,会根据HTTP规范返回相应的日期格式。
4.设置Expires头标。
代码如下:
header ("Expires: " . gmdate ("r", ($max + $interval)));
5.设置Cache_Control头标。
代码如下:
header ("Cache-Control: max-age=$interval");
本文标题为:PHP下利用header()函数设置浏览器缓存的代码
基础教程推荐
- PHP实现抽奖系统的示例代码 2023-06-26
- php实现数组筛选奇数和偶数示例 2024-02-05
- PHP+MySQL+sphinx+scws实现全文检索功能详解 2023-01-31
- php数组函数序列之array_sum() – 计算数组元素值之和 2024-01-15
- PHP判断一个字符串是否是回文字符串的方法 2024-01-31
- PHP手机短信验证码实现流程详解 2022-10-18
- Yii框架连表查询操作示例 2023-02-13
- PHP实现文件下载【实例分享】 2024-04-27
- php实现构建排除当前元素的乘积数组方法 2022-11-23
- 设定php简写功能的方法 2023-03-17
