Warning: Cannot modify header information - headers already sent by (output started at

今天在WordPress中文论坛逛了一圈。坛子里人气不高,不过还是有很多高手的。会编写插件和模版的高手和连编辑文件都不会的初学者混在一起,论坛就是这样,哈哈。

看到好几个帖子里提到同一个错误,比如这个帖子里提到的:"Warning: Cannot modify header information - headers already sent by (output started at c:\program files\easyphp1-8\www\wp-config.php:1) in c:\program files\easyphp1-8\www\wp-login.php on line 9"

这是一个很典型的问题。WordPress的程序执行时会首先调用wp-config.php一类的配置文件,也会调用wp-db.php建立数据库连接以备后用。这些文件只是做一些设置,并不输出html代码。设置完了后,程序本身开始执行了,有些程序会使用header命令设置一个HTTP头。由于HTTP头必须在html代码输出之前设置好,否则html代码已经开始往客户端发送了,HTTP也就已经发送过了,没法追回来重新设置了。WordPress CodeX里对这个问题作出了说明:《How do I solve the Headers already sent warning problem?》。文章指出:要确保各个文件——尤其是经常被编辑的wp-config.php文件——以<?php开头,以?>结尾,前后不能有其他字符。具体到上面的例子,很明显,提示信息说wp-config.php的第一行就开始了html输出,这有可能是第一行的<?php部分前面被加上的其他字符,比如空格一类的。再联想到以前提到的BOM的问题,那么非常有可能是因为这位朋友使用了Windows的记事本编辑了wp-config.php文件并保存成了UTF-8编码的文档,从而因为BOM的三个字符的输出造成了header命令执行出错。

WordPress中文论坛没有提供全文搜索的功能,只能搜索标题,所以我用Google搜索了一下Cannot modify header information site:wordpress.org.cn,好像碰到这个问题的人还真不少。目前大家用的WordPress主要是WordPress英文原版和几个WordPress中文版。我的中文包又不包含wp-config-sample.php文件,自然不关我的事;WordPress原版用的ASCII码,自然不包含BOM,也不会出这样的错误;xigang制作的WordPress中文版在WordPress中文论坛有下,我去下载了WordPress 2.0.4和2.0.3这两个,检查了一下,没有问题;点点游的WordPress 2.0.4中文版里,wp-config-sample.php文件用的是GB2312编码和DOS行尾符,GOD!不过这样也好,如果有人用记事本修改了这个文件,DOS行尾符不会造成编辑问题,GB2312编码不会造成BOM的问题,呼。

唉,如果你要用WordPress架Blog,还是扔掉记事本,装个UltraEdit或者EditPlus吧!

Update:那些提示(output started at \wp-includes\wp-db.php:104)的,我打开wp-db.php文件看了一下,104行好像是输出数据库错误的呀。还是检查一下你的数据库连接,还有是不是IIS上才会有这个问题呀?

本文共有 20 条评论Warning: Cannot modify header information - headers already sent by (output started at


  1. 1 youngshine

    Thanks.

  2. 2 keenen

    晕,原来这里早有说明了,我还准备在WordPress中文论坛发贴问呢
    谢谢yskin

  3. 3 donald

    老大 是不是用iis就会出这个错?
    Warning: Cannot modify header information - headers already sent by (output started at G:\Bolg\wordpress2.07cn\wp-admin\setup-config.php:23) in G:\Bolg\wordpress2.07cn\wp-includes\wp-db.php on line 315
    我2.1英 2.07中英都试过 不行阿 mysql 没问题阿

  4. 4 yskin

    那倒不是IIS上一定不能用WordPress,一般来说,个人架的IIS,有可能由于不会配置,从而导致很多问题。

    setup-config.php的23行看不出有啥问题。

  5. 5 cyf1234567

    原来是这样的,我的问题解决了,就是引用的文件里面有空格什么的

  6. 6 薇薇

    ~调试我的系统时老是出现未知错误,我也有把空格都删了,还是没有用啊Warning: Cannot modify header information - headers already sent by (output started at D:\Apache2\htdocs\shop\lib\class.php:282) in D:\Apache2\htdocs\shop\login.php on line 54

  7. 7 匿名

    按时

  8. 8 leo

    请问大家伙,是否按照提示修改他那一行啊 

  9. 9 很暈

    確實是BOM文件頭的問題,我讓EditPlus默認總是加入BOM頭。
    去掉了就正常了,謝謝!

  10. 10 MonoTony

    谢谢!成了!!原来后面有回车,不能有!!!!!!!!!!

  11. 11 小四

    或许和DB_CHARSET 有关系,改为gbk看看~~

  12. 12 raypig

    果然是编码的问题.
    我最爱的wordpad...不能用了...
    谢谢你.

  1. 1 Unlockey.com » Blog Archive » Warning: Cannot modify header information - headers already sent by (output started at
  2. 2 wordpress的中文版和中文汉化版 at Lost Temple
    Pingback2006-10-29 8:20 下午
  3. 3 P268博客 » Blog Archive » wordpress错误,rss不能用?Warning: Cannot modify header information - headers already sent by (output started at
  4. 4 DONKEYBLOG » Blog Archive » 今天换了程序
  5. 5 阿邙-離離濁濁... » 一个Warning
    Pingback2007-6-24 5:26 上午
  6. 6 冰山上的播客 » Blog Archive » 配置文件wp-config.php基础
    Pingback2007-11-2 2:48 上午
  7. 7 wp-config.php 完全配置指南 at 第七封印
    Pingback2008-5-21 2:06 上午
  8. 8 wp-config.php 完全配置指南
    Pingback2008-8-22 9:20 下午

请留下您的评论: