首頁  >  文章  >  後端開發  >  怎麼解決php不相容問題

怎麼解決php不相容問題

藏色散人
藏色散人原創
2021-02-07 09:29:032948瀏覽

php不相容的解決方法:1、更改「my.cnf」來指定字元集;2、透過「alter user 'root'@'%' identified with...」方式更新已存在的帳號密碼;3、重新安裝Mysql8.0即可。

怎麼解決php不相容問題

本文操作環境:windows7系統、PHP7.1版,DELL G3電腦。

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。

推薦:《PHP影片教學

我們可以指定加密方式來設定:

# 新建用户,使用旧版加密方式设置密码
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。

總結

mysql8.0有什麼新的特性我沒有詳細查看文檔,但是兼容性先讓我吃了一頓苦頭,還好在解決完這3個問題後,我的PHP程式成功跑了起來,下面我要去升級PHP5.1到PHP7了。

以上是怎麼解決php不相容問題的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn