徹底杜絕PHP的session cookie錯誤
本文討論的是如何徹底杜絕warning: Cannot add header information - headers already sent in...... 這種令人莫明其妙的的錯誤。
只要你寫過PHP代碼,相信都遇上過這個大多時候都令人莫明其妙的warning吧..今天我們就來搞定它...............
看了PHP手冊,回答如下:
消息“Warning: Cannot send session cookie - headers already sent。。。”或者“Cannot add header information - headers already sent。。。”。
函數(shù) header(),setcookie() 和 session 函數(shù)需要在輸出流中增加頭信息。但是頭信息只能在其它任何輸出內(nèi)容之前發(fā)送。在使用這些函數(shù)前不能有任何(如 HTML)的輸出。函數(shù) headers_sent() 能夠檢查您的腳本是否已經(jīng)發(fā)送了頭信息。請參閱“輸出控制函數(shù)”。
意思是:不要在使用上面的函數(shù)前有任何文字,空行,回車,空格等。但。。。問題是,這答案并不令人滿意。因為往往程序在其他PHP環(huán)境下運行卻正常。
首先:這錯誤是怎么產(chǎn)生的呢?讓我們來看看PHP是如何處理HTTP header輸出和主體輸出的。
PHP腳本開始執(zhí)行時,它可以同時發(fā)送header(標題)信息和主體信息。 Header信息(來自 header() 或 SetCookie() 函數(shù))并不會立即發(fā)送,相反,它被保存到一個列表中。 這樣就可以允許你修改標題信息,包括缺省的標題(例如 Content-Type 標題)。但是,一旦腳本發(fā)送了任何非標題的輸出(例如,使用 HTML 或 print() 調(diào)用),那么PHP就必須先發(fā)送完所有的Header,然后終止 HTTP header。而后繼續(xù)發(fā)送主體數(shù)據(jù)。從這時開始,任何添加或修改Header信息的試圖都是不允許的,并會發(fā)送上述的錯誤消息之一。
好!那我們來解決它:
笨方法:把錯誤警告全不顯示!
掩耳盜鈴之計,具體方法就不說了 ^_^#
解決方案:
1)適用于有權(quán)限編輯PHP。INI的人
打開php。ini文件(你應(yīng)試比我清楚你的php。ini在哪里),找到
output_buffering =改為on或者任何數(shù)字。如果是IIS6,請一定改為ON,不然你的PHP效率會奇慢。
2)使用虛擬主機,不能編輯PHP。INI,怎么辦?
簡單:
在你的空間根目錄下建立一個。htaccess文件,內(nèi)容如下:
AllowOverride All
PHP_FLAG output_buffering On
不幸的情況是:還是不行?全部網(wǎng)頁都不能顯示啦?
那么,你可以打電話罵一通空間商,然后讓他給你把apache的。htaccess AllowOverride打開
3)在PHP文件里解決
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。
ob_get_contents()
將當前的output buffer返回成一個字符串。允許你處理腳本發(fā)出的任何輸出。
原理:
output_buffering被啟用時,在腳本發(fā)送輸出時,PHP并不發(fā)送HTTP header。相反,它將此輸出通過管道(pipe)輸入到動態(tài)增加的緩存中(只能在PHP 4。0中使用,它具有中央化的輸出機制)。你仍然可以修改/添加header,或者設(shè)置cookie,因為header實際上并沒有發(fā)送。當全部腳本終止時,PHP將自動發(fā)送HTTP header到瀏覽器,然后再發(fā)送輸出緩沖中的內(nèi)容。
關(guān)鍵詞:PHP,session,cookie
閱讀本文后您有什么感想? 已有 人給出評價!
- 1
- 1
- 1
- 1
- 1
- 1