Maison >développement back-end >tutoriel php >php output_buffering 缓存使用介绍

php output_buffering 缓存使用介绍

WBOY
WBOYoriginal
2016-07-25 08:55:201368parcourir
  1. for($i=0; $i echo $i.'
    ';
  2. sleep(2);
  3. }
  4. ?>
复制代码

运行结果:等所有脚本全部运行完成后,才输出,因为数据未满一个buffer的大小。

例2,output_buffering=4096,输出较少的数据(少于一个buffer),关闭output_buffering,修改php.ini的output_buffering=0

  1. for($i=0; $i echo $i.str_repeat(" ",500).'
    '; // 当接受到的256(甚至更多)个字节以后才开始显示该页面,所以必须发送一些额外的空格来让这些浏览器显示页面内容。
  2. flush();
  3. sleep(1);
  4. }
  5. ?>
复制代码

运行结果: 因为禁用了php buffering,不需要等到脚本运行完毕就可以输出,数据没有在php buffer停留,可以看到断断续续间歇性输出。 echo -> tcp buffer ->browser

例3,当output_buffering=4096,输出较大数据(大于一个buffer),不使用ob_start()

  1. for($i=0; $i echo file_get_contents('f.txt').$i.'
    ';
  2. sleep(1);
  3. }
  4. ?>
复制代码

运行结果: f.txt为一个大于4kb的文件,因为大于buffer默认值,buffer空间不够用,每当满一个buffer就会输出,所以可以看到间歇性输出。

例4,当output_buffering=4096,输出较大数据(大于一个buffer),使用ob_start()

  1. ob_start();
  2. for($i=0; $i echo file_get_contents('f.txt').$i.'
    ';
  3. sleep(1);
  4. }
  5. ?>
复制代码

运行结果: 因为使用了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_clean ob_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也可以,只不过为了保证代码的可移植性,建议配套使用。



Déclaration:
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn