- for($i=0; $i<10; $i++){
- echo $i.'
';
- sleep(2);
- }
- ?>
-
複製代碼運行結果:等所有指令碼全部運行完成後,才輸出,因為資料未滿一個buffer的大小。 例2,output_buffering=4096,輸出較少的資料(少於一個buffer),關閉output_buffering,修改php.ini的output_buffering=0
- for($i=0; $i<10; $i++){
- echo $i.str_repeat(" ",500).'
'; // 當接受到的256(甚至更多)個位元組以後才開始顯示該頁面,所以必鬚髮送一些額外的空格來讓這些瀏覽器顯示頁面內容。
- flush();
- sleep(1);
- }
- ?>
-
複製代碼運行結果:因為禁用了php buffering,不需要等到指令碼運行完畢就可以輸出,資料沒有在php buffer停留,可以看到斷斷續續間歇性輸出。echo -> tcp buffer ->browser 例3,當output_buffering=4096,輸出較大資料(大於一個buffer),不使用ob_start()
- for($i=0; $i<10; $i++){
- echo file_get_contents('f.txt').$i.'
';
- sleep(1);
- }
- ?>
-
複製代碼運行結果:f.txt為一個大於4kb的檔案,因為大於buffer預設值,buffer空間不夠用,每當滿一個buffer就會輸出,所以可以看到間歇性輸出。 例4,當output_buffering=4096,輸出較大資料(大於一個buffer),使用ob_start()
- ob_start();
- for($i=0; $i<10; $i++){
- echo file_get_contents('f.txt').$i.'
';
- sleep(1);
- }
- ?>
-
複製代碼運行結果:因為使用了ob_start(),會為buffer設定足夠大的空間,因此會儲存到指令碼執行完畢後才會輸出。 output_buffering 方法1.ob_start啟用output_buffering機制,一旦啟用,指令碼不再直接輸出到瀏覽器,而是暫時寫入php buffering地區。直到指令碼運行完畢後,才發送。 2.ob_get_contents擷取php buffering中的資料,注意:要在ob_end_clean()前調用,否則只會得到Null 字元。 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 標記的開頭之前緩衝內容,並且在接受到 |