徹底杜絕PHP的session cookie錯誤
更新時間:2009年08月09日 00:57:46 作者:
本文討論的是如何徹底杜絕warning: Cannot add header information - headers already sent in...... 這種令人莫明其妙的的錯誤。
只要你寫過PHP代碼,相信都遇上過這個大多時候都令人莫明其妙的warning吧..今天我們就來搞定它...............
看了PHP手冊,回答如下:
消息“Warning: Cannot send session cookie - headers already sent。。?!被蛘摺癈annot 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(標(biāo)題)信息和主體信息。 Header信息(來自 header() 或 SetCookie() 函數(shù))并不會立即發(fā)送,相反,它被保存到一個列表中。 這樣就可以允許你修改標(biāo)題信息,包括缺省的標(biāo)題(例如 Content-Type 標(biāo)題)。但是,一旦腳本發(fā)送了任何非標(biāo)題的輸出(例如,使用 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()
將當(dāng)前的output buffer返回成一個字符串。允許你處理腳本發(fā)出的任何輸出。
原理:
output_buffering被啟用時,在腳本發(fā)送輸出時,PHP并不發(fā)送HTTP header。相反,它將此輸出通過管道(pipe)輸入到動態(tài)增加的緩存中(只能在PHP 4。0中使用,它具有中央化的輸出機制)。你仍然可以修改/添加header,或者設(shè)置cookie,因為header實際上并沒有發(fā)送。當(dāng)全部腳本終止時,PHP將自動發(fā)送HTTP header到瀏覽器,然后再發(fā)送輸出緩沖中的內(nèi)容。
看了PHP手冊,回答如下:
消息“Warning: Cannot send session cookie - headers already sent。。?!被蛘摺癈annot 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(標(biāo)題)信息和主體信息。 Header信息(來自 header() 或 SetCookie() 函數(shù))并不會立即發(fā)送,相反,它被保存到一個列表中。 這樣就可以允許你修改標(biāo)題信息,包括缺省的標(biāo)題(例如 Content-Type 標(biāo)題)。但是,一旦腳本發(fā)送了任何非標(biāo)題的輸出(例如,使用 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()
將當(dāng)前的output buffer返回成一個字符串。允許你處理腳本發(fā)出的任何輸出。
原理:
output_buffering被啟用時,在腳本發(fā)送輸出時,PHP并不發(fā)送HTTP header。相反,它將此輸出通過管道(pipe)輸入到動態(tài)增加的緩存中(只能在PHP 4。0中使用,它具有中央化的輸出機制)。你仍然可以修改/添加header,或者設(shè)置cookie,因為header實際上并沒有發(fā)送。當(dāng)全部腳本終止時,PHP將自動發(fā)送HTTP header到瀏覽器,然后再發(fā)送輸出緩沖中的內(nèi)容。
您可能感興趣的文章:
- PHP會話控制:Session與Cookie詳解
- php session和cookie使用說明
- php中如何同時使用session和cookie來保存用戶登錄信息
- php設(shè)置session值和cookies的學(xué)習(xí)示例
- PHP5中Cookie與 Session使用詳解
- 深入理解PHP中的Session和Cookie
- ThinkPHP的cookie和session沖突造成Cookie不能使用的解決方法
- thinkphp中session和cookie無效的解決方法
- PHP中cookie和session的區(qū)別實例分析
- 解析PHP的Yii框架中cookie和session功能的相關(guān)操作
- php中session與cookie的比較
- 對比分析php中Cookie與Session的異同
- PHP入門教程之會話控制技巧(cookie與session)
相關(guān)文章
阿里云的WindowsServer2016上部署php+apache
這篇文章主要介紹了阿里云的WindowsServer2016上部署php+apache的相關(guān)資料,需要的朋友可以參考下2018-07-07PHP自定義圖片縮放函數(shù)實現(xiàn)等比例不失真縮放的方法
這篇文章主要介紹了PHP自定義圖片縮放函數(shù)實現(xiàn)等比例不失真縮放的方法,結(jié)合實例形式分析了php圖片縮放函數(shù)的功能實現(xiàn)與使用技巧,需要的朋友可以參考下2016-08-08Linux系統(tǒng)下php獲得系統(tǒng)分區(qū)信息的方法
這篇文章主要介紹了Linux系統(tǒng)下php獲得系統(tǒng)分區(qū)信息的方法,涉及Linux下php系統(tǒng)分析的操作技巧,具有一定參考借鑒價值,需要的朋友可以參考下2015-03-03那些年我們錯過的魔術(shù)方法(Magic Methods)
PHP 對象的一個優(yōu)勢是可以使用魔術(shù)方法,這些方法可以不需要修改外部代碼而重寫一個類的默認(rèn)行為,這使得PHP 語法有更少的冗余性和更具有擴展性。這些方法很好識別,他們都是以雙下劃線(__)開始的2014-01-01PHP使用CURL實現(xiàn)多線程抓取網(wǎng)頁
PHP 利用 Curl 可以完成各種傳送文件操作,比如模擬瀏覽器發(fā)送GET,POST請求等等,然而因為php語言本身不支持多線程,所以開發(fā)爬蟲程序效率并不高,不過可以用 Curl ,借助Curl 這個功能實現(xiàn)并發(fā)多線程的訪問多個url地址以實現(xiàn)并發(fā)多線程抓取網(wǎng)頁或者下載文件2015-04-04PHP和Selenium搭建高效網(wǎng)絡(luò)爬蟲實現(xiàn)技術(shù)探索
隨著信息時代的到來,網(wǎng)站被認(rèn)為是獲取信息的主要途徑之一,但是,手動獲取網(wǎng)站上的信息是非常繁瑣的,因此出現(xiàn)了自動抓取網(wǎng)頁的方式——網(wǎng)絡(luò)爬蟲,這篇文章將介紹如何使用PHP和Selenium搭建一個高效的網(wǎng)絡(luò)爬蟲來自動收集信息2024-01-01php將數(shù)組轉(zhuǎn)換成csv格式文件輸出的方法
這篇文章主要介紹了php將數(shù)組轉(zhuǎn)換成csv格式文件輸出的方法,涉及php操作csv文件的技巧,非常具有實用價值,需要的朋友可以參考下2015-03-03