关于PHP中的Cannot modify header information的解决问题

2009-07-16 14:49 0 条评论 »

刚刚接触php,在做页面定义Header输出的时候碰到了个小问题。

Warning: Cannot modify header information – headers already sent by (output started at H:\root\…\a.php:1) in H:\root\…\b.php on line 11

网上找了下资料说是有可能是因为a.php里面有空格或空行造成,但是全部处理干净后还是有这个问题。

var_dump(headers_list());

显示http头信息如下

array(2) {
  [0]=>
  string(23) “X-Powered-By: PHP/5.2.3″
  [1]=>
  string(23) “Content-type: text/html”
}

说明a.php有其他内容,只是编辑器没有显示出来。

后来网上找到这篇文章,http://www.cnitblog.com/CoffeeCat/archive/2008/12/15/52629.html。看了之后更加明了。 

摘录如下:

有时候并没有输出任何东西,却还是会出现这个错误,这是因为我们的文件包含了BOM签名

请看测试代码:

<?php
header(”content-type:text/html;charset=utf-8″);
die();
?>

这段代码就是简单的header一下,在<?php之前也没有任何输出,也没有空格,但是网页里还是提示了Cannot modify header information的警告信息。这说明,在<?php之前还有内容,只是编辑器没有显示出来。

我们用ultraEdit打开这个文件,切换到16进制,可以看到,在文本的开头,有EFBBBF,之后才是3C 3F 70 68 70 ( <?php ),说明,在<?php之前,确实存在着输出信息,因此,在修改header的时候,会得到警告信息。

这个EFBBBF是什么东西呢?它的名字叫BOM,Byte Order Mark,是在Windows下的一个约定,用于标记文本是否是Unicode。记事本程序就是通过这三个字节来判断文件是ANSI还是Unicode。

知道了问题发生的原因,下面,我们想办法把BOM去掉。用Dreamweaver打开这个php页面,然后进入页面设置(按Ctrl+J),弹出以下窗口:
  

取消选择“包括Unicode签名(BOM)”,确定就可以了。现在,我们再用UltraEdit打开看这个文件的16进制内容,如下图

可以看到,现在BOM信息已经没有了,文件直接以3C3F70开头了。

最后,我们刷新一下浏览器,发现现在已经没有Warning提示了,问题解决。

评论