PHP输出缓冲和发送header报错怎么办
Admin 2022-09-22 群英技术资讯 875 次浏览
这篇文章给大家介绍了“PHP输出缓冲和发送header报错怎么办”的相关知识,讲解详细,步骤过程清晰,有一定的借鉴学习价值,因此分享给大家做个参考,感兴趣的朋友接下来一起跟随小编看看吧。如果你在header或cookie函数前发送大量字符到浏览器,就会报headers already sent 错误,以下为说明:
此函数告诉我们发送header的状态。如果将输出发送到浏览器,则不应使用重定向等header函数。为避免此类错误,我们可以使用headers_sent()函数检查header发送状态。它根据标头的状态返回TRUE或FALSE。当我们执行一个php脚本时,将输出存储到缓冲区中,然后再将其发送到浏览器。但是,这还取决于您的服务器php.ini设置,其中必须打开或关闭输出缓冲区。
output_buffering = Off
现在,由于关闭了输出缓冲,因此所有输出都将发送到浏览器。让我们通过一个例子来学习。
<?Php
echo 'Hello p2hp.com';
echo "<br><br>";
if (!headers_sent()) {
echo " 没有header发送,你可以进行发送header或cookie ";
}else{
echo " Header已经发送,你不能再发送header或cookie了 ";
}
?>
以上代码的输出将取决于你的php.ini设置。对于我们来说,我们的php.ini默认是:
output_buffering 4096 4096
在上面的第一行代码中,我们将输出发送到浏览器,但是仍然得到header_sent()没有发送header,因为缓冲区尚未将输出发送到浏览器。所以我们将得到这样的输出
没有header发送,你可以进行发送header或cookie
因此,要将输出发送到浏览器,我们必须耗尽输出缓冲区的容量。这里是4096。因此,我们将尝试向浏览器发送更多输出以超出限制,然后检查if条件以了解header发送状态。
<?php
for ($i=1; $i<=372; $i++) {
echo "p2hp.com - ";
}
echo "<br><br>";
if (!headers_sent()) {
// 没有header发送,你可以进行发送header或cookie //
echo '没有header发送,你可以进行发送header或cookie';
// header("HTTP/1.1 301 Moved Permanently");
// header ("Location: mynewpage1.html");
exit;
} else {
// Header已经发送,你不能再发送header或cookie了 //
echo 'Header已经发送,你不能再发送header或cookie了';
header("Location: mynewpage1.html");// Warning: Cannot modify header information - headers already sent by xxxxx
}
在上面的代码中,您可以通过增加或减少$ i值来调整for循环。循环数越高,意味着将有更多的数据发布到缓冲区。尝试通过增加$i的最大值来查看headers_sent()在哪里变为TRUE。
我们可以使用flush()强制将缓冲区输出发送到浏览器。但是,这取决于服务器,并且可能会以不同的方式工作。
参考 https://www.plus2net.com/php_tutorial/headers_sent.php
到此,关于“PHP输出缓冲和发送header报错怎么办”的学习就结束了,希望能够解决大家的疑惑,另外大家动手实践也很重要,对大家加深理解和学习很有帮助。如果想要学习更多的相关知识,欢迎关注群英网络资讯站,小编每天都会给大家分享实用的文章!
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:mmqy2019@163.com进行举报,并提供相关证据,查实之后,将立刻删除涉嫌侵权内容。
猜你喜欢
学习laravel框架,对于路由的内是需要的掌握的,本文就给大家介绍关于Laravel框架路由设置、路由办法、路由参数等等内容,有这方面学习需要的朋友可以参考参考。
GC如其名就是垃圾收集,当然这里仅就内存而言,下面这篇文章主要给大家介绍了关于PHP中GC回收机制利用的相关资料,文中通过图文介绍的非常详细,需要的朋友可以参考下
在本篇文章里小编给大家分享了关于PHP删除字符串中非字母数字字符方法和知识点,有需要的朋友们学习下。
众所周知,PHP7使用率很高,有需要的朋友可以看看,列出一些容易踩雷的坑,并给出方法讲解,方法干练有效。
这篇文章主要介绍了php伪协议实现命令执行详情,文章围绕主题展开详细的内容介绍,感兴趣的朋友可以参考一下
成为群英会员,开启智能安全云计算之旅
立即注册关注或联系群英网络
7x24小时售前:400-678-4567
7x24小时售后:0668-2555666
24小时QQ客服
群英微信公众号
CNNIC域名投诉举报处理平台
服务电话:010-58813000
服务邮箱:service@cnnic.cn
投诉与建议:0668-2555555
Copyright © QY Network Company Ltd. All Rights Reserved. 2003-2020 群英 版权所有
增值电信经营许可证 : B1.B2-20140078 粤ICP备09006778号 域名注册商资质 粤 D3.1-20240008