徹底杜絕PHP的session cookie錯(cuò)誤
更新時(shí)間:2009年08月09日 00:57:46 作者:
本文討論的是如何徹底杜絕warning: Cannot add header information - headers already sent in...... 這種令人莫明其妙的的錯(cuò)誤。
只要你寫過PHP代碼,相信都遇上過這個(gè)大多時(shí)候都令人莫明其妙的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ù)前有任何文字,空行,回車,空格等。但。。。問題是,這答案并不令人滿意。因?yàn)橥绦蛟谄渌鸓HP環(huán)境下運(yùn)行卻正常。
首先:這錯(cuò)誤是怎么產(chǎn)生的呢?讓我們來看看PHP是如何處理HTTP header輸出和主體輸出的。
PHP腳本開始執(zhí)行時(shí),它可以同時(shí)發(fā)送header(標(biāo)題)信息和主體信息。 Header信息(來自 header() 或 SetCookie() 函數(shù))并不會立即發(fā)送,相反,它被保存到一個(gè)列表中。 這樣就可以允許你修改標(biāo)題信息,包括缺省的標(biāo)題(例如 Content-Type 標(biāo)題)。但是,一旦腳本發(fā)送了任何非標(biāo)題的輸出(例如,使用 HTML 或 print() 調(diào)用),那么PHP就必須先發(fā)送完所有的Header,然后終止 HTTP header。而后繼續(xù)發(fā)送主體數(shù)據(jù)。從這時(shí)開始,任何添加或修改Header信息的試圖都是不允許的,并會發(fā)送上述的錯(cuò)誤消息之一。
好!那我們來解決它:
笨方法:把錯(cuò)誤警告全不顯示!
掩耳盜鈴之計(jì),具體方法就不說了 ^_^#
解決方案:
1)適用于有權(quán)限編輯PHP。INI的人
打開php。ini文件(你應(yīng)試比我清楚你的php。ini在哪里),找到
output_buffering =改為on或者任何數(shù)字。如果是IIS6,請一定改為ON,不然你的PHP效率會奇慢。
2)使用虛擬主機(jī),不能編輯PHP。INI,怎么辦?
簡單:
在你的空間根目錄下建立一個(gè)。htaccess文件,內(nèi)容如下:
AllowOverride All
PHP_FLAG output_buffering On
不幸的情況是:還是不行?全部網(wǎng)頁都不能顯示啦?
那么,你可以打電話罵一通空間商,然后讓他給你把a(bǔ)pache的。htaccess AllowOverride打開
3)在PHP文件里解決
ob_start()
啟用output buffering機(jī)制。 Output buffering支持多層次 -- 例如,可以多次調(diào)用 ob_start() 函數(shù)。
ob_end_flush()
發(fā)送output buffer(輸出緩沖)并禁用output buffering機(jī)制。
ob_end_clean()
清除output buffer但不發(fā)送,并禁用output buffering。
ob_get_contents()
將當(dāng)前的output buffer返回成一個(gè)字符串。允許你處理腳本發(fā)出的任何輸出。
原理:
output_buffering被啟用時(shí),在腳本發(fā)送輸出時(shí),PHP并不發(fā)送HTTP header。相反,它將此輸出通過管道(pipe)輸入到動態(tài)增加的緩存中(只能在PHP 4。0中使用,它具有中央化的輸出機(jī)制)。你仍然可以修改/添加header,或者設(shè)置cookie,因?yàn)閔eader實(shí)際上并沒有發(fā)送。當(dāng)全部腳本終止時(shí),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ù)前有任何文字,空行,回車,空格等。但。。。問題是,這答案并不令人滿意。因?yàn)橥绦蛟谄渌鸓HP環(huán)境下運(yùn)行卻正常。
首先:這錯(cuò)誤是怎么產(chǎn)生的呢?讓我們來看看PHP是如何處理HTTP header輸出和主體輸出的。
PHP腳本開始執(zhí)行時(shí),它可以同時(shí)發(fā)送header(標(biāo)題)信息和主體信息。 Header信息(來自 header() 或 SetCookie() 函數(shù))并不會立即發(fā)送,相反,它被保存到一個(gè)列表中。 這樣就可以允許你修改標(biāo)題信息,包括缺省的標(biāo)題(例如 Content-Type 標(biāo)題)。但是,一旦腳本發(fā)送了任何非標(biāo)題的輸出(例如,使用 HTML 或 print() 調(diào)用),那么PHP就必須先發(fā)送完所有的Header,然后終止 HTTP header。而后繼續(xù)發(fā)送主體數(shù)據(jù)。從這時(shí)開始,任何添加或修改Header信息的試圖都是不允許的,并會發(fā)送上述的錯(cuò)誤消息之一。
好!那我們來解決它:
笨方法:把錯(cuò)誤警告全不顯示!
掩耳盜鈴之計(jì),具體方法就不說了 ^_^#
解決方案:
1)適用于有權(quán)限編輯PHP。INI的人
打開php。ini文件(你應(yīng)試比我清楚你的php。ini在哪里),找到
output_buffering =改為on或者任何數(shù)字。如果是IIS6,請一定改為ON,不然你的PHP效率會奇慢。
2)使用虛擬主機(jī),不能編輯PHP。INI,怎么辦?
簡單:
在你的空間根目錄下建立一個(gè)。htaccess文件,內(nèi)容如下:
AllowOverride All
PHP_FLAG output_buffering On
不幸的情況是:還是不行?全部網(wǎng)頁都不能顯示啦?
那么,你可以打電話罵一通空間商,然后讓他給你把a(bǔ)pache的。htaccess AllowOverride打開
3)在PHP文件里解決
ob_start()
啟用output buffering機(jī)制。 Output buffering支持多層次 -- 例如,可以多次調(diào)用 ob_start() 函數(shù)。
ob_end_flush()
發(fā)送output buffer(輸出緩沖)并禁用output buffering機(jī)制。
ob_end_clean()
清除output buffer但不發(fā)送,并禁用output buffering。
ob_get_contents()
將當(dāng)前的output buffer返回成一個(gè)字符串。允許你處理腳本發(fā)出的任何輸出。
原理:
output_buffering被啟用時(shí),在腳本發(fā)送輸出時(shí),PHP并不發(fā)送HTTP header。相反,它將此輸出通過管道(pipe)輸入到動態(tài)增加的緩存中(只能在PHP 4。0中使用,它具有中央化的輸出機(jī)制)。你仍然可以修改/添加header,或者設(shè)置cookie,因?yàn)閔eader實(shí)際上并沒有發(fā)送。當(dāng)全部腳本終止時(shí),PHP將自動發(fā)送HTTP header到瀏覽器,然后再發(fā)送輸出緩沖中的內(nèi)容。
您可能感興趣的文章:
- PHP會話控制:Session與Cookie詳解
- php session和cookie使用說明
- php中如何同時(shí)使用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ū)別實(shí)例分析
- 解析PHP的Yii框架中cookie和session功能的相關(guān)操作
- php中session與cookie的比較
- 對比分析php中Cookie與Session的異同
- PHP入門教程之會話控制技巧(cookie與session)
相關(guān)文章
PHP中使用break跳出多重循環(huán)代碼實(shí)例
這篇文章主要介紹了PHP中使用break跳出多重循環(huán)代碼實(shí)例,本文直接給出代碼,代碼簡潔易一懂,一看就明白了,需要的朋友可以參考下2015-01-01
php簡單實(shí)現(xiàn)單態(tài)設(shè)計(jì)模式的方法分析
這篇文章主要介紹了php簡單實(shí)現(xiàn)單態(tài)設(shè)計(jì)模式的方法,簡單分析了單態(tài)設(shè)計(jì)模式的構(gòu)成、實(shí)現(xiàn)與使用方法,需要的朋友可以參考下2017-07-07
php使用fopen創(chuàng)建utf8編碼文件的方法
這篇文章主要介紹了php使用fopen創(chuàng)建utf8編碼文件的方法,是涉及編碼問題需要注意的一個(gè)技巧,需要的朋友可以參考下2014-10-10
在PHP中使用反射技術(shù)的架構(gòu)插件使用說明
基于反射的插件架構(gòu)實(shí)際上并沒有歸類為一種模式,因?yàn)樗鼘?shí)際上不是一個(gè)模板,而是一糸列組合在一起的形成程序架構(gòu)的概念。2010-05-05
學(xué)習(xí)php設(shè)計(jì)模式 php實(shí)現(xiàn)抽象工廠模式
這篇文章主要介紹了php設(shè)計(jì)模式中的抽象工廠模式,使用php實(shí)現(xiàn)抽象工廠模式,感興趣的小伙伴們可以參考一下2015-12-12
php實(shí)現(xiàn)的返回?cái)?shù)據(jù)格式化類實(shí)例
這篇文章主要介紹了php實(shí)現(xiàn)的返回?cái)?shù)據(jù)格式化類及其應(yīng)用實(shí)例,包括針對XML、JSON等的格式化,非常具有實(shí)用價(jià)值,需要的朋友可以參考下2014-09-09
php轉(zhuǎn)換上傳word文件為PDF的方法【基于COM組件】
這篇文章主要介紹了php轉(zhuǎn)換上傳word文件為PDF的方法,結(jié)合實(shí)例形式分析了php基于COM組件針對word文件的格式轉(zhuǎn)換相關(guān)操作技巧,需要的朋友可以參考下2019-06-06

