這篇文章將為大家詳細講解有關php不兼容怎么辦,小編覺得挺實用的,因此分享給大家做個參考,希望大家閱讀完這篇文章后可以有所收獲。
創新互聯是一家集網站建設,隴川企業網站建設,隴川品牌網站建設,網站定制,隴川網站建設報價,網絡營銷,網絡優化,隴川網站推廣為一體的創新建站企業,幫助傳統企業提升企業形象加強企業競爭力。可充分滿足這一群體相比中小企業更為豐富、高端、多元的互聯網需求。同時我們時刻保持專業、時尚、前沿,時刻以成就客戶成長自我,堅持不斷學習、思考、沉淀、凈化自己,讓我們為更多的企業打造出實用型網站。
php不兼容的解決辦法:1、更改“my.cnf”來指定字符集;2、通過“alter user 'root'@'%' identified with...”方式更新已存在的賬號密碼;2、重新安裝MySQL8.0即可。
PHP與Mysql8不兼容問題匯總
在安裝Mysql8.0之后,需要跟我們原有的PHP進行協同工作,然而原先與Mysql5.1能夠很好協同的代碼,突然報錯,看來需要做一些額外的工作。
報錯:PDO::__construct(): Server sent charset (255) unknown to the client. Please, report to the developers
根據網上資料顯示,是由于Mysql8.0將默認的字符集改為了utfmb4,因此和客戶端(不僅僅是PHP)的通信無法識別,我們需要更改my.cnf來指定字符集。
[client] default-character-set=utf8 [mysql] default-character-set=utf8 [mysqld] collation-server = utf8_unicode_ci character-set-server = utf8 報錯:PDO::__construct(): The server requested authentication method unknown to the client [caching_sha2_password]
根據網上資料顯示,是由于用戶身份認證的加密方式不兼容導致的,mysql8.0中默認方式為caching_sha2_password,引起老版本兼容性問題,老版本加密方式為mysql_native_password。
我們可以指定加密方式來設置:
# 新建用戶,使用舊版加密方式設置密碼 CREATE USER username@localhost identified with mysql_native_password by 'password'; # 更新已存在的賬號密碼加密方式 alter user 'root'@'%' identified with mysql_native_password by 'password';
但更好的方式是加一行默認配置:
[mysqld] default_authentication_plugin = mysql_native_password 報錯:Access denied for user 'root'@'localhost' (using password: YES) mysql> GRANT ALL PRIVILEGES ON *.* TO 'oss'@'%'; ERROR 1045 (28000): Access denied for user 'root'@'localhost' (using password: YES)
在我給其他用戶加權限的時候,報錯無權限,原因是我一不小心刪掉了root身份的用戶,雖然網上有很多的文檔解決這個問題,但是我重建后的root用戶雖然擁有Grant_priv: Y但依然無法成功分配權限,我很頭疼。
解決方法:重裝,參考文章安裝Mysql8.0。
關于“php不兼容怎么辦”這篇文章就分享到這里了,希望以上內容可以對大家有一定的幫助,使各位可以學到更多知識,如果覺得文章不錯,請把它分享出去讓更多的人看到。
當前名稱:php不兼容怎么辦
當前鏈接:http://m.newbst.com/article32/pjdipc.html
成都網站建設公司_創新互聯,為您提供網站收錄、動態網站、服務器托管、響應式網站、外貿網站建設、建站公司
聲明:本網站發布的內容(圖片、視頻和文字)以用戶投稿、用戶轉載內容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網站立場,如需處理請聯系客服。電話:028-86922220;郵箱:631063699@qq.com。內容未經允許不得轉載,或轉載時需注明來源: 創新互聯