這篇文章主要介紹了php中的output_buffering詳細介紹,本文講解了output buffering的一些高級用法,需要的朋友可以參考下
我個人認為,output buffering是比較純粹的4.0特征。盡管從概念上看來相當(dāng)簡單,但是output buffering功能非常強大,能使開發(fā)者更容易地開發(fā)高級而有效的程序。
本文將介紹http header,以及output buffering如何幫助您處理http header,并介紹了output buffering的一些高級用法。
http header
對 于使用http 協(xié)議建立的每個請求,web服務(wù)器產(chǎn)生的響應(yīng)通常包括兩個部分 – 標(biāo)題和主體。例如,如果在web服務(wù)器的文檔根目錄下有一個小文本文件,叫做example.txt,文件中包含文本hello, world!,那么對此文件的http 請求響應(yīng)如下所示:
代碼如下:
http/1.1 200 ok
date: sat, 02 sep 2000 21:40:08 gmt
server: apache/1.3.11 (unix) mod_macro/1.1.1 php/4.0.2-dev
last-modified: sat, 02 sep 2000 21:39:49 gmt
etag: 12600b-e-39b173a5
accept-ranges: bytes
content-length: 14
connection: close
content-type: text/plain
hello, world!
這 個請求中的第一部分(就是較多的那部分)就是http header。雖然用戶在瀏覽器中看不到http header,但它包含了用于瀏覽器的信息,例如文檔內(nèi)容類型,使用的協(xié)議版本,文檔的最后更改日期等等。http header并沒有太多的規(guī)則,通常情況下,它的格式如下:
代碼如下:
field: value[字段:值]
必須用空行將它們和文檔主體分開。
可以從php腳本添加或更改此http header的信息。例如,可以使用 header() 函數(shù):
代碼如下:
header(location:); // 重定向到
也可以使用 setcookie() 函數(shù):
代碼如下:
setcookie(foo, bar);
你可能會知道http cookies是使用 http headers 來實現(xiàn)的。例如,以下php文件的 http 請求響應(yīng)
代碼如下:
<?php
setcookie(foo, bar);
print set cookie.;
?>
將會是這樣的:
代碼如下:
http/1.1 200 ok
date: sat, 02 sep 2000 21:43:02 gmt
server: apache/1.3.11 (unix) mod_macro/1.1.1php/4.0.2-dev
x-powered-by: php/4.0.2-dev
set-cookie: foo=bar
connection: close
content-type: text/html
set cookie.
瀏覽器讀取從服務(wù)器返回的 http header,知道送來了一個叫做 foo 的 cookie (在這里是一個 session cookie),它的值是 bar。
為什么要使用output buffering技術(shù)
早 在php/fi 2.0時就很明顯需要output buffering技術(shù)了。如果你使用過這種版本的php,那么可能還記得經(jīng)常會碰到 oops, setcookie called after header has been sent 這個錯誤消息,并使你捎頭抓耳,也弄不清是什么原因。
如 果你已使用過php的最新版本 -- php 3.0 甚至 php 4.0 -- 那么你會知道這個錯誤消息: oops, php_set_cookie called after header has been sent。或者,你在試圖調(diào)用 php 的 header() 函數(shù)時會遇到 cannot add header information - headers already sent 消息。一般來說,output buffering技術(shù)用戶避免這些煩人的錯誤消息,同時開發(fā)人員也可用于高級的用途。
這些錯誤是什么時候產(chǎn)生的呢?如果你在已經(jīng)發(fā)送了http header之后試圖添加或修改標(biāo)題信息,以及在文檔主體和標(biāo)題之間缺少空行時,就會產(chǎn)生這些錯誤消息。為了理解這是如何產(chǎn)生的,讓我們來看看php是如何處理http header輸出和主體輸出的。
腳本開始執(zhí)行時,它可以同時發(fā)送header(標(biāo)題)信息和主體信息。
header信息(來自 header() 或 setcookie() 函數(shù))并不會立即發(fā)送,相反,它被保存到一個列表中。
這樣就可以允許你修改標(biāo)題信息,包括缺省的標(biāo)題(例如 content-type 標(biāo)題)。但是,一旦腳本發(fā)送了任何非標(biāo)題的輸出(例如,使用塊或 print() 調(diào)用),那么php就必須先發(fā)送所有的標(biāo)題,然后再送出空行,終止 http header,而在此之后才會繼續(xù)發(fā)送主體數(shù)據(jù)。從這時開始,任何添加或修改標(biāo)題信息的試圖都是不允許的,并會發(fā)送上述的錯誤消息之一。
雖然這并不會引起多大的問題,有時候只是在發(fā)出任何輸入之前終止http header,從而引起腳本邏輯的復(fù)雜化而已。output buffering技術(shù)可以解決這些問題。
output buffering的工作原理
啟用output buffering時,在腳本發(fā)送輸出時,php并 不發(fā)送http header。相反,它將此輸出通過管道(pipe)輸入到動態(tài)增加的緩存中(只能在php 4.0中使用,它具有中央化的輸出機制)。你仍然可以修改,添加標(biāo)題行,或者設(shè)置cookie,因為標(biāo)題實際上并沒有發(fā)送。最簡單的情況是,當(dāng)腳本終止 時,php將自動發(fā)送http header到瀏覽器,然后再發(fā)送輸出緩沖中的內(nèi)容。這簡單吧。
基本用法
可以使用下面的四個函數(shù),它們可以幫助你控制output buffering:
代碼如下:
ob_start()
啟用output buffering機制。
output buffering支持多層次 -- 例如,可以多次調(diào)用 ob_start() 函數(shù)。
ob_end_flush()
發(fā)送output buffer(輸出緩沖)并禁用output buffering機制。
ob_end_clean()
清除output buffer但不發(fā)送,并禁用output buffering。
更多信息請查看IT技術(shù)專欄