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