复制代码
运行结果:等所有脚本全部运行完成后,才输出,因为数据未满一个buffer的大小。
例2,output_buffering=4096,输出较少的数据(少于一个buffer),关闭output_buffering,修改php.ini的output_buffering=0
复制代码
运行结果:因为禁用了php buffering,不需要等到脚本运行完毕就可以输出,数据没有在php buffer停留,可以看到断断续续间歇性输出。echo -> tcp buffer ->browser
例3,当output_buffering=4096,输出较大数据(大于一个buffer),不使用ob_start()
复制代码
运行结果:f.txt为一个大于4kb的文件,因为大于buffer默认值,buffer空间不够用,每当满一个buffer就会输出,所以可以看到间歇性输出。
例4,当output_buffering=4096,输出较大数据(大于一个buffer),使用ob_start()
复制代码
运行结果:因为使用了ob_start(),会为buffer设置足够大的空间,因此会保存到脚本执行完毕后才会输出。
output_buffering 方法1.ob_start激活output_buffering机制,一旦激活,脚本不再直接输出到浏览器,而是暂时写入php buffering区域。直到脚本运行完毕后,才发送。
2.ob_get_contents获取php buffering中的数据,注意:要在ob_end_clean()前调用,否则只会得到空字符。
3.ob_end_flush 和 ob_end_cleanob_end_flush 会输出php buffering 中的数据,但不会清空。ob_end_clean 不会输出,只会清空php buffering中的数据。
注意:ob_flush/flush在手册中的描述,都是刷新输出缓冲区,并且还需要配套使用。其实, 他们俩的操作对象不同, 有些情况下, flush根本不做什么事情。
ob_*系列函数, 是操作php本身的输出缓冲区.所以, ob_flush是刷新php自身的缓冲区。
而flush, 严格来讲, 这个只有在php做为apache的module(handler或者filter)安装时,才有实际作用。它是刷新webserver(可以认为特指apache)的缓冲区.在apache module的sapi下, flush会通过调用sapi_module的flush成员函数指针,间接调用apache的api: ap_rflush刷新apache的输出缓冲区。
有些apache的模块,比如mod_gzip,可能自己进行输出缓存,这将导致flush()函数产生的结果不会立即被发送到客户端浏览器。甚至浏览器也会在显示之前,缓存接收到的内容。
例如,netscape浏览器会在接受到换行或 html 标记的开头之前缓存内容,并且在接受到
标记之前,不会显示出整个表格。一些版本的 microsoft internet explorer 只有当接受到的256个字节以后才开始显示该页面,所以必须发送一些额外的空格来让这些浏览器显示页面内容。正确的使用顺序为:先ob_flush,后flush。当然,在其他sapi下,不调用flush也可以,只不过为了保证代码的可移植性,建议配套使用。