用织梦cms做的网站转到新空间后,网站管理后台无法登录了,输入网址竟然显示空白,什么都没有了。下面就给大空分享下一些解决织梦后台登录空间的方法。
方法一:修改include/userlogin.class.php文件
找到include/userlogin.class.php,把这六行代码注释掉:
@session_register($this->keepUserIDTag);
@session_register($this->keepUserTypeTag);
@session_register($this->keepUserChannelTag);
@session_register($this->keepUserNameTag);
@session_register($this->keepUserPurviewTag);
@session_register($this->keepAdminStyleTag);
原因:这个文件里有一个keepUser()函数,它是用session_register来注册一个session变量,但是在php5.4中已经移除了这个功能。
dedecms-login-page-goes-blank-solutions-1
方法二:文件替换法
找到:include/common.inc.php文件
//error_reporting(E_ALL);
error_reporting(E_ALL || ~E_NOTICE);
替换为:
error_reporting(E_ALL);
//error_reporting(E_ALL || ~E_NOTICE);
这样做的目是可以在你访问网站的时候,在浏览器窗口告诉你那里出错了,或者是那个文件出错了。你可以根据这些提示,找到之前网站正常运行时备份的文件,替换就可以了。替换完成后记得要把include/common.inc.php改回来
error_reporting(E_ALL);
//error_reporting(E_ALL || ~E_NOTICE);
替换为:
//error_reporting(E_ALL);
error_reporting(E_ALL || ~E_NOTICE);
方法三:BOM去除法
去除BOM法:BOM 是“Byte Order Mark”的缩写,用于标记文件的编码。并不是所有的文本编辑工具都能识别BOM标记.在用记事本之类的程序将文本文件保存为UTF-8格式时,记事本会在文件头前面加上几个不可见的字符(EF BB BF),就是所谓的BOM(Byte Order Mark)。
<?php //remove the utf-8 boms //by magicbug at gmail dot com if (isset($_GET['dir'])){ //要去除的文件目录,无参数则为文件当前目录www.lol9.cn。 $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.</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); } ?>
把以上代码拷贝到txt文件里,保存成.php文件,上传到网站根目录,然后用域名+文件名.php访问就可以了。
方法四:PHP.ini设置
思路:既然程序是从一个空间搬到另一个空间的,说明不出什么意外的话程序本身是没问题的。那么问题还可以出现在哪里呢。空间商!也就是说空间商提供的空间的管理后台里的PHP.ini设置禁止某些不该禁止的功能