在运行脚本时,我会遇到以下几个错误:
警告:无法修改标头信息-标头已由第23行的/some/file.php中的/some-file.php发送(输出开始于/some/files.php:12)
错误消息中提到的行包含header()和setcookie()调用。
这可能是什么原因?如何修复?
在运行脚本时,我会遇到以下几个错误:
警告:无法修改标头信息-标头已由第23行的/some/file.php中的/some-file.php发送(输出开始于/some/files.php:12)
错误消息中提到的行包含header()和setcookie()调用。
这可能是什么原因?如何修复?
当前回答
常见问题:
(复制自:源)
====================
1) 在标题(……..)之前不应有任何输出(即echo...或HTML代码);命令
2) 删除<?php及其之后?>标签。
3) 黄金法则!-检查php文件(如果包含其他文件)是否具有UTF8而没有BOM编码(而不仅仅是UTF-8)。这在很多情况下都是一个问题(因为UTF8编码的文件在php文件的开头有一个特殊的字符,而您的文本编辑器不会显示)!!!!!!!!!!!
4) 在标题(…)之后;您必须使用exit;
5) 始终使用301或302参考:
header("location: http://example.com", true, 301 ); exit;
6) 打开错误报告并查找错误。您的错误可能是由于某个函数不工作导致的。打开错误报告时,应始终首先修复最顶部的错误。例如,它可能是“警告:date_default_timezone_get():依赖系统的时区设置是不安全的。”-然后往下看,您可能会看到“headers not send”错误。修复最上面(第一个)错误后,重新加载页面。如果仍有错误,请再次修复最上面的错误。
7) 如果以上任何一项都没有帮助,请使用JAVSCRIPT重定向(但是,强烈不推荐的方法),这可能是自定义情况下的最后机会…:
echo "<script type='text/javascript'>window.top.location='http://website.com/';</script>"; exit;
其他回答
另一种不良做法可能会引发尚未说明的问题。
请参见以下代码段:
<?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之前,这是不允许的。您不能在标题之前发送任何输出,甚至不能发送空行。
常见问题:
(复制自:源)
====================
1) 在标题(……..)之前不应有任何输出(即echo...或HTML代码);命令
2) 删除<?php及其之后?>标签。
3) 黄金法则!-检查php文件(如果包含其他文件)是否具有UTF8而没有BOM编码(而不仅仅是UTF-8)。这在很多情况下都是一个问题(因为UTF8编码的文件在php文件的开头有一个特殊的字符,而您的文本编辑器不会显示)!!!!!!!!!!!
4) 在标题(…)之后;您必须使用exit;
5) 始终使用301或302参考:
header("location: http://example.com", true, 301 ); exit;
6) 打开错误报告并查找错误。您的错误可能是由于某个函数不工作导致的。打开错误报告时,应始终首先修复最顶部的错误。例如,它可能是“警告:date_default_timezone_get():依赖系统的时区设置是不安全的。”-然后往下看,您可能会看到“headers not send”错误。修复最上面(第一个)错误后,重新加载页面。如果仍有错误,请再次修复最上面的错误。
7) 如果以上任何一项都没有帮助,请使用JAVSCRIPT重定向(但是,强烈不推荐的方法),这可能是自定义情况下的最后机会…:
echo "<script type='text/javascript'>window.top.location='http://website.com/';</script>"; exit;
有时,当开发过程同时具有WIN工作站和LINUX系统(托管),并且在代码中,在相关行之前没有看到任何输出时,可能是文件的格式和缺少Unix LF(linefeed)行结束。
为了快速解决这个问题,我们通常要做的是重命名文件,在LINUX系统上创建一个新文件而不是重命名的文件,然后将内容复制到其中。很多时候,这解决了这个问题,因为WIN中创建的一些文件一旦移动到主机,就会导致这个问题。
对于我们通过FTP管理的站点,此修复程序非常简单,有时可以节省新团队成员的一些时间。