ホームページ >バックエンド開発 >PHPチュートリアル >PHP を MySQL 8.0 に接続すると「認証方法が一致しません」エラーが発生するのはなぜですか?

PHP を MySQL 8.0 に接続すると「認証方法が一致しません」エラーが発生するのはなぜですか?

Susan Sarandon
Susan Sarandonオリジナル
2024-12-05 10:58:09558ブラウズ

Why Am I Getting a

PHP と MySQL 8.0 エラー: 認証方法の不一致

PHP から MySQL データベースに接続すると、ユーザーはエラー「SQLSTATE[HY000] [2054]サーバーがクライアントに不明な認証方法を要求しました。」この問題は、MySQL で使用される認証方法とクライアント アプリケーションで予期される方法が一致しないために発生します。

原因:

MySQL 8.0 では、デフォルトの認証プラグインが導入されました。これは caching_sha2_password と呼ばれ、古い PHP バージョンや一部のクライアント アプリケーションではネイティブにサポートされていません。デフォルトでは、アプリケーションはパスワードベースの方法を使用して認証することを想定していますが、MySQL 8.0 では caching_sha2_password プラグインの使用が必要です。

解決策:

エラーを解決するには、 MySQL で使用される認証方法を、アプリケーションで期待される方法と一致するように変更する必要があります。次の手順に従ってください:

  1. root ユーザーとして MySQL にログインします。
  2. 次のコマンドを実行して、root ユーザーの認証方法を mysql_native_password に変更します:
ALTER USER 'root'@'localhost' IDENTIFIED WITH mysql_native_password BY 'password';

「パスワード」を root に置き換えます

  1. アプリケーションがデータベースへの接続に別のユーザーを使用する場合は、上記のコマンドの「root」を適切なユーザーに置き換えてください。
  2. 変更のために MySQL サービスを再起動します。

追加注:

  • お使いの PHP バージョンが caching_sha2_password メソッドをサポートしていることを確認してください。そうでない場合は、PHP を互換性のあるバージョンに更新します。
  • 認証方法とプラグインの詳細については、MySQL ドキュメントを参照してください。
  • 認証方法を変更しても問題が解決しない場合は、ユーザーがデータベースにアクセスするために必要な権限を持っています。

以上がPHP を MySQL 8.0 に接続すると「認証方法が一致しません」エラーが発生するのはなぜですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。