-
Dedecms使用Mysql8.0无法登录后台的解决方法
- 时间:2025-03-30 05:36:08 来源: 人气:0
今天,一位客户联系了我们的技术支持团队,反馈说在安装完成后,登录后台时一直提示“用户名不存在”。通常,这种情况可能由两个原因引起:1、数据库连接信息不正确;2、数据库表中的用户名不是默认的“admin”,而是被修改过。然而,经过多方排查,我们发现这两个原因均不成立,最终定位到问题的根源在于该客户使用的是 MySQL 8.0 数据库。
MySQL 8.0 引入了一些新的语法规则和限制条件,这些规则与 Dedecms CMS 自带的后台用户登录检查语句中指定的表别名存在冲突,从而导致了这个 bug。那么,如何解决这个问题呢?
首先,我们需要找到 Dedecms 的文件目录,在 include
子目录下定位到 userlogin.class.php
文件。打开该文件后,找到大约第 249 行的位置,可以看到如下代码:
// 只允许用户名和密码用 0-9, a-z, A-Z, '@', '_', '.', '-' 这些字符
$this->userName = preg_replace("/[^0-9a-zA-Z_@!\\.-]/", '', $username);
$this->userPwd = preg_replace("/[^0-9a-zA-Z_@!\\.-]/", '', $userpwd);
$pwd = substr(md5($this->userPwd), 5, 20);
$dsql->SetQuery("SELECT admin.*,atype.purviews FROM `dede_admin` admin LEFT JOIN `dede_admintype` atype ON atype.rank=admin.usertype WHERE admin.userid LIKE '".$this->userName."' LIMIT 0,1");
$dsql->Execute();
$row = $dsql->GetObject();
在这段代码中,$dsql->SetQuery
是用来设定将要执行的 SQL 语句的,而下一行的 $dsql->Execute()
则是执行这条语句。为了解决 MySQL 8.0 的兼容性问题,我们需要对这条 SQL 语句进行修改。
具体来说,我们将原来的 SQL 语句中的表别名从“admin”改为“admi”,以避免与 MySQL 8.0 的新规则冲突。修改后的代码如下所示:
// 只允许用户名和密码用 0-9, a-z, A-Z, '@', '_', '.', '-' 这些字符
$this->userName = preg_replace("/[^0-9a-zA-Z_@!\\.-]/", '', $username);
$this->userPwd = preg_replace("/[^0-9a-zA-Z_@!\\.-]/", '', $userpwd);
$pwd = substr(md5($this->userPwd), 5, 20);
$dsql->SetQuery("SELECT admi.*,atype.purviews FROM `dede_admin` admi LEFT JOIN `dede_admintype` atype ON atype.rank=admi.usertype WHERE admi.userid LIKE '".$this->userName."' LIMIT 0,1");
$dsql->Execute();
$row = $dsql->GetObject();
完成上述修改后,保存文件并重新测试登录功能。此时,您应该能够正常登录后台管理系统。
总结一下,MySQL 8.0 的新特性可能会与某些老旧系统的 SQL 语句产生冲突。通过调整表别名,可以有效解决 Dedecms 在 MySQL 8.0 环境下的登录问题。如果您遇到类似的问题,请按照上述步骤操作,并确保所有更改符合系统要求。
相关文章
-
在网站建设与维护的过程中,优化代码结构和功能是提升网站性能的重要步骤。本文将介绍如何通过自定义函数实现文章删除时自动清理相关资源的功能,从而提高系统的整洁性和存储效率。以下是具体的操作步骤及代码实现。首先, 在 `/include` 目录下创建一个名为 `extend.func.php` 的文件...2025-03-31
-
在进行图片上传操作时,用户可能会遇到302错误以及带有ERROR提示的图片上传失败问题。这些问题可能由多种原因引发,因此本文将对这些情况进行整理,以帮助大家更有效地定位并解决问题。 第一种情况:图片文件本身损坏。 这种情况会导致系统返回ERROR错误提示,不过发生概率较低。如果怀疑是图片损坏导致的...2025-03-31
-
如果您正在寻找一种高效的方法来使用Dedecms模板搭建网站或论坛,那么本文将为您提供详尽的指导。从模板解压到最终完成配置,每一步都将清晰呈现,帮助您快速掌握整个流程。 第一步:解压Dedecms模板 将下载的Dedecms模板文件解压出来,确保所有文件完整无误。如下图所示: 第二步:获取D...2025-03-31
-
Dedecms Dede 附加表自定义字段与主表文章关联方法
在使用DedeCMS开发装修网站时,设计师和设计作品之间的关联是一个重要的功能需求。通常情况下,文章(作品)的内容部分存储在主表dede_addonarticle中,而自定义字段则存储在附加表dede_archives中。为了实现这一功能,可以采用以下两种方法。 ① 根据发布人调用相关文章; ...2025-03-31