PHP输出缓冲与header发送问题详解

admin3年前PHP教程30

如果你在header或cookie函数前发送大量字符到浏览器,就会报headers already sent  错误,以下为说明:

headers_sent()

此函数告诉我们发送header的状态。如果将输出发送到浏览器,则不应使用重定向等header函数。为避免此类错误,我们可以使用headers_sent()函数检查header发送状态。它根据标头的状态返回TRUE或FALSE。当我们执行一个php脚本时,将输出存储到缓冲区中,然后再将其发送到浏览器。但是,这还取决于您的服务器php.ini设置,其中必须打开或关闭输出缓冲区。


output_buffering = Off

现在,由于关闭了输出缓冲,因此所有输出都将发送到浏览器。让我们通过一个例子来学习。


<?Php
echo 'Hello p2hp';
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 - ";
}
echo "<br><br>";
if (!headers_sent()) {
    // 没有header发送,你可以进行发送header或cookie //
    echo '没有header发送,你可以进行发送header或cookie';
    // header("HTTP/1.1 301 Moved Permanently");
    // header ("Location: mynewpage1");
    exit;
} else {
    // Header已经发送,你不能再发送header或cookie了 //
    echo 'Header已经发送,你不能再发送header或cookie了';
    header("Location: mynewpage1");// Warning: Cannot modify header information - headers already sent by xxxxx
}

在上面的代码中,您可以通过增加或减少$ i值来调整for循环。循环数越高,意味着将有更多的数据发布到缓冲区。尝试通过增加$i的最大值来查看headers_sent()在哪里变为TRUE。

我们可以使用flush()强制将缓冲区输出发送到浏览器。但是,这取决于服务器,并且可能会以不同的方式工作。

参考  plus2net/php_tutorial/headers_sent.php

总结

到此这篇关于PHP输出缓冲与header发送问题的文章就介绍到这了,更多相关PHP输出缓冲header发送内容请搜索以前的文章或继续浏览下面的相关文章希望大家以后多多支持!

免责声明:本文内容来自用户上传并发布,站点仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。请核实广告和内容真实性,谨慎使用。

相关文章

详解PHP的执行原理和流程

简介先看看下面这个过程:• 我们从未手动开启过PHP的相关进程,它是随着Apache的启动而运行的;• PHP通过mod_php5.so模块和Apache相连(具体说来是SAPI,...

详解Swoole跟传统的web开发的区别

一、swoole的运行模式1.1、传统web开发模式PHP web开发采用的方式是LAMP/LNMP架构,即Linux、Nginx,Mysql和PHP。这里以nginx来举例,大致结构为:当请求进入时...

PHP如何打印跟踪调试信息

目录debug_backtrace()debug_print_backtrace()总结对于大部分编译型语言来说,比如 C 、 Java 、 C# ,我们都能很方便地进行断点调试,但是 PHP 则必须...

泉州高防服务器防御方式是怎么样的

泉州高防服务器的防御方式主要有以下几种:流量清洗:流量清洗是高防服务器最基本的防御方式,它通过对所有进入服务器的流量进行实时监测和分析,检测出异常流量并将其过滤掉,从而保证服务器正常运行。这种方式可以...

杭州BGP高防服务器租用优势有哪些

杭州BGP高防服务器租用的优势包括:高防能力强:BGP高防服务器采用了BGP路由协议和多线接入技术,能够有效地抵御各种DDoS攻击和黑客入侵,确保您的网站和服务器的安全和稳定运行。带宽大:BGP高防服...

PHP创建简单RPC服务案例详解

RPC 定义RPC(Remote Procedure Call)即远程过程调用,指被调用方法的具体实现不在程序运行本地,而是在别的某个地方。主要应用于不同的系统之间的远程通信和相互调用。如 A 调用...