帝国cms提示您的cookie没有开启,不能登录成功
加入收藏 2022-08-06 50人浏览

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

您的Cookie没有开启,不能登陆成功

查阅资料,总结了这个问题的出现原因,暂时只发现了两个。

原因一:

其实,并非代码或者配置的问题,而是文件开头有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

添加至收藏