dedecms使用Mysql8.0無法登錄後台的解決辦法

字號+ 編輯: 种花家 修訂: 德玛西亚 來源: 原创 2023-09-12 我要說兩句(1)

找了半天,發現dede在後台用戶登錄檢查語句上和mysql 8.0的語句限制要求有關係。

6月28號阿裡雲polarDB宕機後, 被迫把一部分老客戶用的數據遷移到自架的MySQL 8.0服務裡面。客戶用的是dedecms, 下午打電話說後台登錄不上去了, 29號抽空找了半天, 終於看到是因mysql 8.0新制定的語句表名限制條件被dede自帶的後台用戶登錄檢查語句指定表別名所違背而引起的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 `#@__admin` admin LEFT JOIN `#@__admintype` atype ON atype.rank=admin.usertype WHERE admin.userid LIKE '".$this->userName."' LIMIT 0,1");
        $dsql->Execute();
        $row = $dsql->GetObject();

其中SetQuery就是設定將要執行的sql語句, 下一行Execute()來執行這個設定好語句,我們從語句裡面改。改成如下:

        //只允許用戶名和密碼用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 `#@__admin` admi LEFT JOIN `#@__admintype` atype ON atype.rank=admi.usertype WHERE admi.userid LIKE '".$this->userName."' LIMIT 0,1");
        $dsql->Execute();
        $row = $dsql->GetObject();

這樣一來,表的別名從admin刪去一個n被改成admi, 就可以正常登錄後台了。

任何其他問題可以加QQ群: 2702237

閲完此文,您的感想如何?
  • 有用

    0

  • 沒用

    0

  • 開心

    0

  • 憤怒

    0

  • 可憐

    0

1.如文章侵犯了您的版權,請發郵件通知本站,該文章將在24小時内刪除;
2.本站標注原創的文章,轉發時煩請注明來源;
3.交流群: 2702237 13835667

相關課文
  • mac開發接入微信公衆號接口返回報錯 cURL error 56: SSLRead() return error -9806

  • PHP的換行符是什麽

  • pecl安裝程序時報錯Array and string offset access syntax with curly braces is no longer supported

  • 由於商家傳入的H5交易參數有誤,該筆交易暫時無法完成,請聯繫商家解決

我要說說
網上賓友點評
1 樓 IP 106.50.***.27 的嘉賓 说道 : 很久前
路过看