ホームページ >バックエンド開発 >PHPチュートリアル >PHP を MySQL 8.0 に接続すると「認証方法が一致しません」エラーが発生するのはなぜですか?
PHP から MySQL データベースに接続すると、ユーザーはエラー「SQLSTATE[HY000] [2054]サーバーがクライアントに不明な認証方法を要求しました。」この問題は、MySQL で使用される認証方法とクライアント アプリケーションで予期される方法が一致しないために発生します。
原因:
MySQL 8.0 では、デフォルトの認証プラグインが導入されました。これは caching_sha2_password と呼ばれ、古い PHP バージョンや一部のクライアント アプリケーションではネイティブにサポートされていません。デフォルトでは、アプリケーションはパスワードベースの方法を使用して認証することを想定していますが、MySQL 8.0 では caching_sha2_password プラグインの使用が必要です。
解決策:
エラーを解決するには、 MySQL で使用される認証方法を、アプリケーションで期待される方法と一致するように変更する必要があります。次の手順に従ってください:
ALTER USER 'root'@'localhost' IDENTIFIED WITH mysql_native_password BY 'password';
「パスワード」を root に置き換えます
追加注:
以上がPHP を MySQL 8.0 に接続すると「認証方法が一致しません」エラーが発生するのはなぜですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。