PHP輸出緩沖與header發(fā)送問題詳解
如果你在header或cookie函數(shù)前發(fā)送大量字符到瀏覽器,就會報headers already sent 錯誤,以下為說明:
headers_sent()此函數(shù)告訴我們發(fā)送header的狀態(tài)。如果將輸出發(fā)送到瀏覽器,則不應使用重定向等header函數(shù)。為避免此類錯誤,我們可以使用headers_sent()函數(shù)檢查header發(fā)送狀態(tài)。它根據(jù)標頭的狀態(tài)返回TRUE或FALSE。當我們執(zhí)行一個php腳本時,將輸出存儲到緩沖區(qū)中,然后再將其發(fā)送到瀏覽器。但是,這還取決于您的服務器php.ini設置,其中必須打開或關(guān)閉輸出緩沖區(qū)。
output_buffering = Off
現(xiàn)在,由于關(guān)閉了輸出緩沖,因此所有輸出都將發(fā)送到瀏覽器。讓我們通過一個例子來學習。
<?Phpecho ’Hello p2hp.com’;echo '<br><br>';if (!headers_sent()) {echo ' 沒有header發(fā)送,你可以進行發(fā)送header或cookie ';}else{echo ' Header已經(jīng)發(fā)送,你不能再發(fā)送header或cookie了 ';}?>
以上代碼的輸出將取決于你的php.ini設置。對于我們來說,我們的php.ini默認是:
output_buffering 4096 4096
在上面的第一行代碼中,我們將輸出發(fā)送到瀏覽器,但是仍然得到header_sent()沒有發(fā)送header,因為緩沖區(qū)尚未將輸出發(fā)送到瀏覽器。所以我們將得到這樣的輸出
沒有header發(fā)送,你可以進行發(fā)送header或cookie
因此,要將輸出發(fā)送到瀏覽器,我們必須耗盡輸出緩沖區(qū)的容量。這里是4096。因此,我們將嘗試向瀏覽器發(fā)送更多輸出以超出限制,然后檢查if條件以了解header發(fā)送狀態(tài)。
<?phpfor ($i=1; $i<=372; $i++) { echo 'p2hp.com - ';}echo '<br><br>';if (!headers_sent()) { // 沒有header發(fā)送,你可以進行發(fā)送header或cookie // echo ’沒有header發(fā)送,你可以進行發(fā)送header或cookie’; // header('HTTP/1.1 301 Moved Permanently'); // header ('Location: mynewpage1.html'); exit;} else { // Header已經(jīng)發(fā)送,你不能再發(fā)送header或cookie了 // echo ’Header已經(jīng)發(fā)送,你不能再發(fā)送header或cookie了’; header('Location: mynewpage1.html');// Warning: Cannot modify header information - headers already sent by xxxxx}
在上面的代碼中,您可以通過增加或減少$ i值來調(diào)整for循環(huán)。循環(huán)數(shù)越高,意味著將有更多的數(shù)據(jù)發(fā)布到緩沖區(qū)。嘗試通過增加$i的最大值來查看headers_sent()在哪里變?yōu)門RUE。
我們可以使用flush()強制將緩沖區(qū)輸出發(fā)送到瀏覽器。但是,這取決于服務器,并且可能會以不同的方式工作。
參考 https://www.plus2net.com/php_tutorial/headers_sent.php
總結(jié)到此這篇關(guān)于PHP輸出緩沖與header發(fā)送問題的文章就介紹到這了,更多相關(guān)PHP輸出緩沖header發(fā)送內(nèi)容請搜索好吧啦網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持好吧啦網(wǎng)!
相關(guān)文章:
1. 關(guān)于WPF WriteableBitmap類直接操作像素點的問題2. JavaScript前端中的偽類元素before和after使用詳解3. PHP JSAPI調(diào)支付API實現(xiàn)微信支付功能詳解4. asp取整數(shù)mod 有小數(shù)的就自動加15. 源碼分析MinimalApi是如何在Swagger中展示6. ThinkPHP5實現(xiàn)JWT Token認證的過程(親測可用)7. ASP基礎(chǔ)入門第一篇(ASP技術(shù)簡介)8. 熊海CMS代碼審計漏洞分析9. 表單中Readonly和Disabled的區(qū)別詳解10. PHP laravel實現(xiàn)基本路由配置詳解
