在运行脚本时,我会遇到以下几个错误:

警告:无法修改标头信息-标头已由第23行的/some/file.php中的/some-file.php发送(输出开始于/some/files.php:12)

错误消息中提到的行包含header()和setcookie()调用。

这可能是什么原因?如何修复?


当前回答

有时,当开发过程同时具有WIN工作站和LINUX系统(托管),并且在代码中,在相关行之前没有看到任何输出时,可能是文件的格式和缺少Unix LF(linefeed)行结束。

为了快速解决这个问题,我们通常要做的是重命名文件,在LINUX系统上创建一个新文件而不是重命名的文件,然后将内容复制到其中。很多时候,这解决了这个问题,因为WIN中创建的一些文件一旦移动到主机,就会导致这个问题。

对于我们通过FTP管理的站点,此修复程序非常简单,有时可以节省新团队成员的一些时间。

其他回答

通常,当我们在回显或打印后发送标头时,会出现此错误。如果在特定页面上出现此错误,请确保该页面在调用start_session()之前没有回显任何内容。

不可预测错误示例:

 <?php //a white-space before <?php also send for output and arise error
session_start();
session_regenerate_id();

//your page content

再举一个例子:

<?php
includes 'functions.php';
?> <!-- This new line will also arise error -->
<?php
session_start();
session_regenerate_id();

//your page content

结论:在调用session_start()或header()函数之前不要输出任何字符,甚至不要输出空格或新行

有时,当开发过程同时具有WIN工作站和LINUX系统(托管),并且在代码中,在相关行之前没有看到任何输出时,可能是文件的格式和缺少Unix LF(linefeed)行结束。

为了快速解决这个问题,我们通常要做的是重命名文件,在LINUX系统上创建一个新文件而不是重命名的文件,然后将内容复制到其中。很多时候,这解决了这个问题,因为WIN中创建的一些文件一旦移动到主机,就会导致这个问题。

对于我们通过FTP管理的站点,此修复程序非常简单,有时可以节省新团队成员的一些时间。

另一种不良做法可能会引发尚未说明的问题。

请参见以下代码段:

<?php
include('a_important_file.php'); //really really really bad practise
header("Location:A location");
?>

一切都很好,对吧?

如果“a_import_file.php”为:

<?php
//some php code 
//another line of php code
//no line above is generating any output
?>

 ----------This is the end of the an_important_file-------------------

这行不通吗?为什么?因为已经生成了一个新行。

现在,虽然这不是一个常见的场景,但如果您使用的是一个MVC框架,该框架在将内容移交给控制器之前加载了大量文件,该怎么办?这种情况并不罕见。做好准备。

来自PSR-2.2:


所有PHP文件必须使用Unix LF(linefeed)行尾。所有PHP文件必须以一个空白行结尾。闭幕式?>标记必须从仅包含php的文件中省略


相信我,遵循这些标准可以为你的生活节省很多时间:)

当在发送HTTP头(带有setcookie或头)之前发送任何内容时,会触发此错误消息。在HTTP头之前输出内容的常见原因是:

意外的空白,通常出现在文件的开头或结尾,例如:<?php文件//注意“<?php”之前的空格?>

为了避免这种情况,只需省略结尾?>-无论如何都不需要。

php文件开头的字节顺序标记。使用十六进制编辑器检查php文件,以确定是否是这种情况。它们应该以字节3F 3C开头。您可以安全地从文件开头删除BOM EF BB BF。显式输出,例如调用echo、printf、readfile、passthru、<?等如果设置了display_errors php.ini属性,则php输出的警告。php不会因程序员错误而崩溃,而是默默地修复错误并发出警告。虽然您可以修改display_errors或error_reporting配置,但您应该解决这个问题。常见的原因是访问数组中未定义的元素(例如$_POST['input'],而不使用空或isset来测试是否设置了输入),或者使用未定义的常量而不是字符串文字(如$_POSD[input],请注意缺少的引号)。

打开输出缓冲将使问题消失;调用obstart之后的所有输出都会缓冲在内存中,直到您释放缓冲区,例如使用obendflush。

然而,虽然输出缓冲避免了这些问题,但您应该真正确定应用程序在HTTP头之前输出HTTP主体的原因。这就像打电话讨论你的日子和天气,然后告诉对方他打错了电话。

你知道

printf ("Hi %s,</br />", $name);

在设置cookie之前,这是不允许的。您不能在标题之前发送任何输出,甚至不能发送空行。