1. 运行时配置(php.ini)
output_buffering = Off
display_errors = On
2. 函数说明
(1)bool ob_start ([ callback $output_callback [, int $chunk_size [, bool $erase ]]] )
此函数将打开输出缓冲。当输出缓冲是活跃的时候,没有输出能从脚本送出(除http标头外),相反输出的内容被存储在内部缓冲区中。内部缓冲区的内容可以用 ob_get_contents() 函数复制到一个字符串变量中。想要输出存储在内部缓冲区中的内容,可以使用 ob_end_flush() 函数。另外,使用ob_end_clean() 函数会静默丢弃掉缓冲区的内容。
| 01 |
| 02 | function callback($buffer) { |
| 03 | // replace all the apples with oranges |
| 04 | return (str_replace("apples", "oranges", $buffer)); |
| 05 | } |
| 06 | ob_start("callback"); |
| 07 | ?> |
| 08 |
| 09 |
| 10 |
it's like comparing apples to oranges. |
| 11 |
| 12 |
| 13 |
| 14 | ob_end_flush(); |
| 15 | ?> |
| 16 |
| 17 | 输出: |
| 18 |
| 19 |
| 20 |
It's like comparing oranges to oranges. |
| 21 |
| 22 |
(2)string ob_get_contents ( void )
只是得到输出缓冲区的内容,但不清除它,或者如果输出缓冲区无效将返回FALSE 。
| 01 |
| 02 | ob_start(); |
| 03 |
| 04 | echo "Hello "; |
| 05 | $out1 = ob_get_contents(); |
| 06 |
| 07 | echo "World"; |
| 08 | $out2 = ob_get_contents(); |
| 09 |
| 10 | ob_end_clean(); |
| 11 | var_dump($out1, $out2); |
| 12 | ?> |
| 13 | 输出:string(6) "Hello " string(11) "Hello World" |
| 14 |
| 15 |
| 16 | //Level 0 |
| 17 | ob_start(); |
| 18 | echo "Hello "; |
| 19 |
| 20 | //Level 1 |
| 21 | ob_start(); |
| 22 | echo "Hello World"; |
| 23 | $out2 = ob_get_contents(); |
| 24 | ob_end_clean(); |
| 25 |
| 26 | //Back to level 0 |
| 27 | echo "Galaxy"; |
| 28 | $out1 = ob_get_contents(); |
| 29 | ob_end_clean(); |
| 30 |
| 31 | //Just output |
| 32 | var_dump($out1, $out2); |
| 33 | ?> |
| 34 | 输出:string(12) "Hello Galaxy" string(11) "Hello World" |
(3)int ob_get_length ( void )
返回输出缓冲区内容的长度;或者返回FALSE——如果没有起作用的缓冲区。
| 1 |
| 2 | ob_start(); |
| 3 | echo "Hello "; |
| 4 | $len1 = ob_get_length(); |
| 5 | echo $len1; |
| 6 | ?> |
| 7 | 输出:6 |
(4)int ob_get_level ( void )
返回嵌套的输出缓冲处理程序的级别;或者是,如果输出缓冲区不起作用,返回零。
| 01 |
| 02 | echo ob_get_level(); // --> 1 |
| 03 | ?> |
| 04 |
| 05 | ob_end_clean(); |
| 06 | echo ob_get_level(); // --> 0 |
| 07 | ?> |
| 08 |
| 09 | echo ob_get_level(); // 1 |
| 10 | ob_start(); |
| 11 | echo "Hello "; |
| 12 | echo ob_get_level(); // 2 |
| 13 |
| 14 | ob_start(); |
| 15 | echo "Hello World"; |
| 16 | echo ob_get_level(); // 3 |
| 17 | $out2 = ob_get_contents(); |
| 18 | ob_end_clean(); |
| 19 |
| 20 | echo "Galaxy"; |
| 21 | $out1 = ob_get_contents(); |
| 22 | ob_end_clean(); |
| 23 | echo ob_get_level(); // 1 |
| 24 |
| 25 | var_dump($out1, $out2); |
| 26 | ?> |
| 27 | 输出:11string(13) "Hello 2Galaxy" string(12) "Hello World3" |
(5)string ob_get_clean ( void )
得到当前缓冲区的内容并删除当前输出缓冲区。如果输出缓冲区不是活跃的,即返回 FALSE 。
ob_get_clean() 实质上是一起执行了 ob_get_contents() 和 ob_end_clean()。
| 01 |
| 02 | ob_start(); |
| 03 | echo "1"; |
| 04 | $content = ob_get_clean(); |
| 05 |
| 06 | ob_start(); // This is NECESSARY for the next ob_get_clean() to work as intended. |
| 07 | echo "2"; |
| 08 | $content .= ob_get_clean(); |
| 09 |
| 10 | echo $content; |
| 11 | ?> |
| 12 | 输出: 12 |
(6)bool ob_end_clean ( void )
此函数丢弃最顶层输出缓冲区的内容并关闭这个缓冲区。如果想要进一步处理缓冲区的内容,必须在ob_end_clean()之前调用ob_get_contents(),因为当调用ob_end_clean()时缓冲区内容将被丢弃。
返回值:成功时返回 TRUE, 或者在失败时返回 FALSE。 错误的原因首先是,在调用时没有一个起作用的缓冲区,或者是因为某些原因缓冲区不能被删除(可能对特殊缓冲区而言)。
错误/异常: 如果函数失败了,将引发一个E_NOTICE异常。
(7)string ob_get_flush ( void )
返回输出缓冲区的内容,并关闭输出缓冲区;如果没有起作用的输出缓冲区,返回FALSE 。
| 01 |
| 02 | //using output_buffering=On |
| 03 | print_r(ob_list_handlers()); |
| 04 |
| 05 | //save buffer in a file |
| 06 | $buffer = ob_get_flush(); |
| 07 | file_put_contents('buffer.txt', $buffer); |
| 08 |
| 09 | print_r(ob_list_handlers()); |
| 10 | ?> 输出: Array ( [0] => default output handler ) Array ( ) |
(8)bool ob_end_flush ( void )
这个函数将送出最顶层缓冲区的内容(如果里边有内容的话),并关闭缓冲区。如果想进一步处理缓冲区中的内容,必须在ob_end_flush()之前调用 ob_get_contents(),因为在调用ob_end_flush()后缓冲区内容被丢弃。
注意: 这个函数与ob_get_flush()相似,不同的是ob_get_flush()会把缓冲区中的内容作为字符串返回。
返回值:成功时返回 TRUE, 或者在失败时返回 FALSE. 错误的原因首先是,在调用时没有一个起作用的缓冲区,或者是因为某些原因缓冲区不能被删除(可能对特殊缓冲区而言)。
错误/异常:如果函数失败了,将引发一个E_NOTICE异常。
(9)void ob_clean ( void )
此函数用来丢弃输出缓冲区中的内容。
此函数不会销毁输出缓冲区,而像 ob_end_clean() 函数会销毁输出缓冲区。
(10)void ob_flush ( void )
这个函数将送出缓冲区的内容(如果里边有内容的话)。如果想进一步处理缓冲区中的内容,必须在ob_flush()之前调用ob_get_contents() ,因为在调用ob_flush()之后缓冲区内容将被丢弃。
此函数不会销毁输出缓冲区,而像ob_end_flush() 函数会销毁缓冲区。
(11)void flush ( void )
刷新PHP程序的缓冲,而不论PHP执行在何种情况下(CGI ,web服务器等等)。该函数将当前为止程序的所有输出发送到用户的浏览器。
flush() 函数不会对服务器或客户端浏览器的缓存模式产生影响。因此,必须同时使用 ob_flush() 和flush() 函数来刷新输出缓冲。
个别web服务器程序,特别是Win32下的web服务器程序,在发送结果到浏览器之前,仍然会缓存脚本的输出,直到程序结束为止。
有些Apache的模块,比如mod_gzip,可能自己进行输出缓存,这将导致flush()函数产生的结果不会立即被发送到客户端浏览器。甚至浏览器也会在显示之前,缓存接收到的内容。例如 Netscape 浏览器会在接受到换行或 html 标记的开头之前缓存内容,并且在接受到 标记之前,不会显示出整个表格。
一些版本的 Microsoft Internet Explorer 只有当接受到的256个字节以后才开始显示该页面,所以必须发送一些额外的空格来让这些浏览器显示页面内容。
3.总结
flush — 刷新输出缓冲
ob_clean — 清空(擦掉)输出缓冲区
ob_end_clean — 清空(擦除)缓冲区并关闭输出缓冲
ob_end_flush — 冲刷出(送出)输出缓冲区内容并关闭缓冲
ob_flush — 冲刷出(送出)输出缓冲区中的内容
ob_get_clean — 得到当前缓冲区的内容并删除当前输出缓冲
ob_get_contents — 返回输出缓冲区的内容
ob_get_flush — 刷出(送出)缓冲区内容,以字符串形式返回内容,并关闭输出缓冲区
ob_get_length — 返回输出缓冲区内容的长度
ob_get_level — 返回输出缓冲机制的嵌套级别
ob_start — 打开输出控制缓冲
PHP怎么学习?PHP怎么入门?PHP在哪学?PHP怎么学才快?不用担心,这里为大家提供了PHP速学教程(入门到精通),有需要的小伙伴保存下载就能学习啦!
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号