登录 WordPress 后台的时候突然发现 WordPress 登录界面提示 “Warning: Cannot modify header information – headers already sent by (output started at /www/wp-content/themes/pozhejun/function.php:1) in /www/wp-login.php on line 21” 的错误信息,其它页面都可以正常访问,就是不能进入后台。

其实,出现这种情况一般都是因为程序修改过程中出现以下几个方面的错误操作导致:

原因一、 UTF8 编码和 BOM 冲突(最常见)

如果你登录后台出现类似 Warning: Cannot modify header information – headers already sent by (output started at /www/wp-content/themes/pozhejun/function.php:1) in /www/wp-includes/pluggable.php on line 897

Warning: Cannot modify header information – headers already sent by (output started at /www/wp-content/themes/pozhejun/function.php:1) in /www/wp-login.php on line 21

这些 php 代码错误,首先考虑是不是 function.php 、 wp-login.php 、 pluggable.php 这三个 PHP 文件的编码出现了问题。一般很有可能是用 txt 文件编辑过这几个报错的文件导致 UTF8 编码和 BOM 冲突。

解决方法:使用 Notepad++、 UltraEdit 、 DW 等编辑器编辑文件,在 “修改” 菜单里面选择 “标题/编码”,将文件编码修改为原本的 gkb 或者 utf-8 格式。当然你也可以把文件另存为,选 ANSI 保存。

原因二:程序文件<?php 之前或者之后有空格(最常见)

解决方法:无论是程序本身 echo 出来的、被 include 进来的程序 echo 的还是 php 代码之外的 HTML 存在空格它们统统都是输出。所以,要检查下出错的 fuction.php 等文件中的<?php..?> 是不是因为空格或者换行导致的,特别是 include 或者 require 的文件。删除空格就能够解决,这也是最常见的报错原因之一。

原因三:插件兼容问题(常见)

如果是安装 WordPress 插件或者自己写的程序出现以上问题,除了以上两种可能,还有可能是 setcookie 的问题。

解决办法:在输出内容之前,产生 cookie,可以在程序的最上方加入函数 ob_start(); 把下面函数加到文件的开头。

<?php ob_start (); ?>

原因四:php.ini 配置问题

解决办法:打开 php.ini 然后把 output_buffering 设为 on , 重启 appache 即可。这种方法开启了所有 php 程序的输出缓存,这样做可能影响 php 执行效率,这取决于服务器的性能和代码的复杂度。

原因五:header 后加 exit()

解决方法:在 header 后加上 exit();

header (“Location: xxx”);

exit();

以上就是 WordPress 出现 “Warning: Cannot modify header information – headers already sent by ……” 这样的错误的常见原因和解决方法,如果是后期运营过程中出现这种情况一般是文件修改或者插件不兼容出现的问题,在解决这个问题之前要清楚出现问题的这段时间到底是修改了什么,这样才能快速的找到出现错误的最终原因,从而快速的解决问题。