手机站 | 电信站 | 联通站|联系电话:18925583550

Dedecms 织梦后台登录空白及验证码空白处理

 

  PHP的版本从5.2.14升到了5.4.15,升级完后dedecms后台却打开空白,检查了各种权限和文件,都没有问题,找来找去,原来是PHP版本函数的问题,它是用session_register来注册一个session变量,但是在php5.4以上中已经移除了这个功能

  解决方法 三种
   方法一:
    (如果php版本降低了的话,请记得原么向操作 改回来,否则也是一片空白)

   找到include/userlogin.class.php,里面有一个keepuser()函数,它是用session_register来注册一个session变量,但是在php5.4中已经移除了这个功能,见官网介绍:
 
  如果使用的该php版本肯定会出错的,不过我们可以修改下代码:
  把@session_register($this->keepUserIDTag); 注释掉,然后改为
if (!isset($_SESSION[$this->keepUserIDTag])) 
  一共有六个,全部改为下面这样:
if (!isset($_SESSION[$this->keepUserIDTag])) 
//@session_register($this->keepUserIDTag); 
 
$_SESSION[$this->keepUserIDTag] = $this->userID; 
 
if (!isset($_SESSION[$this->keepUserTypeTag])) 
//@session_register($this->keepUserTypeTag); 
 
$_SESSION[$this->keepUserTypeTag] = $this->userType; 
 
if (!isset($_SESSION[$this->keepUserChannelTag])) 
//@session_register($this->keepUserChannelTag); 
 
$_SESSION[$this->keepUserChannelTag] = $this->userChannel; 
 
if (!isset($_SESSION[$this->keepUserNameTag])) 
//@session_register($this->keepUserNameTag); 
 
$_SESSION[$this->keepUserNameTag] = $this->userName; 
 
if (!isset($_SESSION[$this->keepUserPurviewTag])) 
//@session_register($this->keepUserPurviewTag); 
 
$_SESSION[$this->keepUserPurviewTag] = $this->userPurview; 
 
if (!isset($_SESSION[$this->keepAdminStyleTag])) 
//@session_register($this->keepAdminStyleTag); 
 
$_SESSION[$this->keepAdminStyleTag] = $adminstyle; 
  重新进入后台登录,就可以正常跳转到管理页面了。
  

方法二(也适合验证码空白)
   服务器上大多没有文本编辑软件,所以直接用记事本来操作,这样就会导致下面的情况。

   data/common.inc.php文件编码的问题,把编码要改为无BOM格式文件保存,居然没有说是php5.4版本的问题
   测试include/vdimgck.php 这个文件如果出现BOM格式的话,验证码不会正常显示。所以BOM问题依然是一个很常见的问题。



方法三:
    还没地遇到过这样的情况,用户可以自己测试下
  在include/helpers/util.helper.php末尾加入以下代码
function fix_session_register(){    
    function session_register(){    
        $args = func_get_args();    
        foreach ($args as $key){    
            $_SESSION[$key]=$GLOBALS[$key];    
        }    
    }    
    function session_is_registered($key){    
        return isset($_SESSION[$key]);    
    }    
    function session_unregister($key){    
        unset($_SESSION[$key]);    
    }    
}    
if (!function_exists('session_register')) fix_session_register(); 



本文源于内容  http://down.chinaz.com/try/201306/2430_1.htm 进行实践后对原文进行了补充和编辑
分享到:

热门关注