首頁 >php教程 >php手册 >php 缓存机制:输出控制

php 缓存机制:输出控制

WBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWB
WBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWB原創
2016-06-21 08:49:501481瀏覽

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 — 打开输出控制缓冲



陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn