之前登录【帝国CMS】后台的时候,出现了如下图的弹框。

查阅资料,总结了这个问题的出现原因,暂时只发现了两个。
原因一:
其实,并非代码或者配置的问题,而是文件开头有BOM导致COOKIE无法送出。
因为在COOKIE送出前PHP已经送出了文件头,所以登入和登出功能失效。其它依赖COOKIE、SESSION实现的功能也将失效。
解决方案1、使用Notepad++、Dreamweaver、UltraEdit等编辑器或软件打开connect.php(connect.php文件位于根目录下的e/class),保存为UTF-8编码的格式。
解决方案2、如果网站有几十个上百个甚至几千上万的文件,推荐新建一个【BOM.PHP】文件,将下方代码粘贴到【BOM.PHP】文件。将【BOM.PHP】文件放到网站根目录,然后通过浏览器打开即可。
<?php
if (isset($_GET['dir'])) {
$basedir = $_GET['dir'];
} else {
$basedir = '.';
}
$auto = 1;
checkdir($basedir);
function checkdir($basedir)
{
if ($dh = opendir($basedir)) {
while (($file = readdir($dh)) !== false) {
if ($file != '.' && $file != '..') {
if (!is_dir($basedir . "/" . $file)) {
echo "filename: {$basedir}/{$file} " . checkBOM("{$basedir}/{$file}") . " <br>";
} else {
$dirname = $basedir . "/" . $file;
checkdir($dirname);
}
}
}
closedir($dh);
}
}
function checkBOM($filename)
{
global $auto;
$contents = file_get_contents($filename);
$charset[1] = substr($contents, 0, 1);
$charset[2] = substr($contents, 1, 1);
$charset[3] = substr($contents, 2, 1);
if (ord($charset[1]) == 239 && ord($charset[2]) == 187 && ord($charset[3]) == 191) {
if ($auto == 1) {
$rest = substr($contents, 3);
rewrite($filename, $rest);
return "<font color=red>BOM found, automatically removed._<a href=https://www.skdy.cc>https://www.skdy.cc</a></font>";
} else {
return "<font color=red>BOM found.</font>";
}
} else {
return "BOM Not Found.";
}
}
function rewrite($filename, $data)
{
$filenum = fopen($filename, "w");
flock($filenum, LOCK_EX);
fwrite($filenum, $data);
fclose($filenum);
}
?>
如果网站域名是www.skdy.cc,那就在浏览器输入www.skdy.cc/BOM.PHP
原因二:
PHP下的php.ini中的output_buffering关闭
解决方案:打开php.ini文件,修改 output_buffering = off 为 output_buffering = 4096,重启apache