时间:2021-05-26
PHP的输出缓存是可以嵌套的。用ob_get_level()就可以输出嵌套级别。
测试发现在cli和浏览器下输出结果不一样(PHP5.4)。
手册说明如下:
ob_get_level() will always return 0 inside a destructor.
This happens because the garbage collection for output buffers has already done before the destructor is called
想要正确输出也很简单:
复制代码 代码如下:
ob_end_clean();
echo ob_get_level(); //0
回到正题:
复制代码 代码如下:
ob_end_clean();
ob_start();
echo 'php1';//此处并不会在页面中输出
$a = ob_get_level();
$b = ob_get_contents();//获得缓存结果,赋予变量
ob_clean();
ob_start();
echo 'php2';//此处并不会在页面中输出
$c = ob_get_level();
$d = ob_get_contents();//获得缓存结果,赋予变量
ob_clean();
ob_start();
echo 'php3';//此处并不会在页面中输出
$e = ob_get_level();
$f = ob_get_contents();//获得缓存结果,赋予变量
ob_clean();
echo 'level:'.$a.',ouput:'.$b.'<br>';
echo 'level:'.$c.',ouput:'.$d.'<br>';
echo 'level:'.$e.',ouput:'.$f.'<br>';
结果如下:
复制代码 代码如下:
level:1,ouput:php1
level:2,ouput:php2
level:3,ouput:php3
当然,当你关闭某个级别的缓冲,如下测试:
复制代码 代码如下:
ob_end_clean();
ob_start();
echo 'php1';
$a = ob_get_level();
$b = ob_get_contents();
ob_clean();
ob_start();
echo 'php2';
$c = ob_get_level();
$d = ob_get_contents();
ob_end_clean(); //清空缓存并关闭缓存
ob_start();
echo 'php3';
$e = ob_get_level();
$f = ob_get_contents();
ob_clean();
echo 'level:'.$a.',ouput:'.$b.'<br>';
echo 'level:'.$c.',ouput:'.$d.'<br>';
echo 'level:'.$e.',ouput:'.$f.'<br>';
结果如下:
复制代码 代码如下:
level:1,ouput:php1
level:2,ouput:php2
level:2,ouput:php3
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
本文实例讲述了php输出缓冲OutputControl用法。分享给大家供大家参考,具体如下:关于php的输出缓冲,首先要说明的是什么是缓冲(buffer),比如
本文实例讲述了php缓冲输出用法。分享给大家供大家参考。具体分析如下:ob_start([stringoutput_callback])-打开输出缓冲区所有的输
ob_*系列函数,是操作PHP本身的输出缓冲区.所以,ob_flush是刷新PHP自身的缓冲区.而flush,严格来讲,这个只有在PHP做为apache的Mod
前言大家都知道PHP的页面静态化有多种实现方式,比如使用输出缓冲(outputbuffering),该种方式是把数据缓存在PHP的缓冲区(内存)中,下一次取数据
PHP里开启实时输出方法是ob_implicit_flush(),但它大部分情况下都不管用,因为php.ini配置里output_buffering输出缓冲大部