setcookie中Cannot modify header information-headers already sent by錯誤的解決方法詳解_PHP教程
推薦:Apache服務器無法使用的解決方法本篇文章介紹了Apache服務器在無法使用時候的一些解決方法。需要的朋友參考下
運行有警告Warning: Cannot modify header information - headers already sent by
下面是別人建議
方法一:
在PHP里Cookie的使用是有一些限制的。
1、使用setcookie必須在<html>標簽之前
2、使用setcookie之前,不可以使用echo輸入內容
3、直到網頁被加載完后,cookie才會出現
4、setcookie必須放到任何資料輸出瀏覽器前,才送出
.....
由于上面的限制,在使用setcookie()函數時,學會遇到 "Undefined index"、"Cannot modify header information - headers already sent by"…等問題,解決辦法是在輸出內容之前,產生cookie,可以在程序的最上方加入函數 ob_start();
ob_start :打開輸出緩沖區
函數格式:void ob_start(void)
說明:當緩沖區激活時,所有來自PHP程序的非文件頭信息均不會發送,而是保存在內部緩沖區。為了輸出緩沖區的內容,可以使用ob_end_flush()或flush()輸出緩沖區的內容。
方法二:
解決Warning: Cannot modify header information - headers already sent by ...... 前幾天裝了個php的大頭貼系統測試,發現報錯Warning: Cannot modify header information - headers already sent by ......
今天又裝openads,還是出現這個問題。怒了。上網找了半天,有人說要在文件開頭寫上
ob_start();
失敗。
后來打開 php.ini 然后把 output_buffering 設為 on 。重起appache,OK。看來這才是解決辦法。
特別注意:(我就是看了這個才解決問題的)
如果使用utf-8編碼,一定要去掉UTF-8中的BOM,這都是因為utf-8編碼文件含有的bom原因,而php4,5都是不支持bom的。去掉bom,可以用Notepad++打開轉換一下。(我就是看了這個才解決問題的)
自己解決辦法
PHP4,5 都不支持utf-8編碼文件中的BOM
分享:PHP 登錄記住密碼實現思路在登錄的時候記住用戶輸入的密碼在某些情況下是很有必要的,下面是一個小例子,感興趣的朋友可以參考下哈,希望對你有所幫助
- 相關鏈接:
復制本頁鏈接| 搜索setcookie中Cannot modify header information-headers already sent by錯誤的解決方法詳解
- 教程說明:
PHP教程-setcookie中Cannot modify header information-headers already sent by錯誤的解決方法詳解
。