|
主要函数:
ob_start()函数:打开输出缓冲区.
函数格式
void ob_start(void)
说明:当缓冲区激活时,所有来自PHP程序的非文件头信息均不会发送,而是保存在内部缓冲区。为了输出缓冲区的内容,可以使用ob_end_flush()或flush()输出缓冲区的内容。
Flush:刷新缓冲区的内容,输出。
函数格式:flush()
说明:这个函数经常使用,效率很高。
ob_get_contents :返回内部缓冲区的内容。
函数格式:string ob_get_contents(void)
说明:这个函数会返回当前缓冲区中的内容,如果输出缓冲区没有激活,则返回 FALSE.
ob_get_length:返回内部缓冲区的长度。
函数格式:int ob_get_length(void)
说明:这个函数会返回当前缓冲区中的长度;和ob_get_contents一样,如果输出缓冲区没有激活,则返回 FALSE.
ob_end_clean:删除内部缓冲区的内容,并且关闭内部缓冲区
函数格式:void ob_end_clean(void)
说明:这个函数不会输出内部缓冲区的内容而是把它删除
ob_end_flush: 发送内部缓冲区的内容到浏览器,并且关闭输出缓冲区
函数格式:void ob_end_flush(void)
说明:这个函数发送输出缓冲区的内容(如果有的话)
ob_implicit_flush:打开或关闭绝对刷新
函数格式:void ob_implicit_flush ([int flag])
说明:默认为关闭缓冲区,打开绝对输出后,每个脚本输出都直接发送到浏览器,不再需要调用 flush()
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
| <?php
ob_start(); //打开输出缓冲区
$cacheTime = 864000; //设置缓存页面过期时间
$cacheDir = ‘cacheDir’; //设置缓存页面文件目录
if (!is_dir($cacheDir)) mkdir($cacheDir); //判断目录是否存在,否则创建目录
$cacheFile = $cacheDir.’/’.(int)date(“Ymd”).’.html’; //缓存文件路径,文件以日期命名
if (!is_file($cacheFile) || time() – filemtime($cacheFile) > $cacheTime) {
<!–页面输出部分内容。也是ob_get_contents()函数取得的全部内容–>
$content = ob_get_contents(); //取得php页面输出的全部内容
$fp = fopen($cacheFile, “w”); //输出内容写入文件
fwrite($fp, $content);
fclose($fp);
} else {
echo $content = file_get_contents($cacheFile); //如果缓存文件已经存在,且未过期则读取
}
?>
|
|
|