ホームページ > データベース > mysql チュートリアル > PHP の「mysqli_connect: 認証方法がクライアントに不明です [caching_sha2_password]」エラーを修正する方法

PHP の「mysqli_connect: 認証方法がクライアントに不明です [caching_sha2_password]」エラーを修正する方法

Patricia Arquette
リリース: 2024-12-28 07:14:46
オリジナル
898 人が閲覧しました

How to Fix the

PHP の「mysqli_connect: クライアントに不明な認証方法 [caching_sha2_password]」を軽減する

MySQL の mysqli_connect を利用してローカル データベースで認証する場合、謎のエラーが発生する可能性があります。 「mysqli_connect(): サーバーはクライアントに不明な認証方法 [caching_sha2_password] を要求しました。」このエラーは、サーバーが使用する認証プラグインとクライアントが予期する認証プラグインが一致しないために発生します。

MySQL サーバーの ini ファイルは、サーバー接続に使用されるデフォルトの認証プラグインを指定します。デフォルトでは、この設定は「caching_sha2_password」に構成されており、サーバーが caching_sha2_password 認証方法を優先することを示します。あなたの場合、サーバーはそれに応じて構成されています。

逆に、PHP コードは、「mysql_native_password」メソッドなどの従来の認証メソッドを使用して接続を試みます。この不一致により認証が失敗し、前述のエラーが発生します。

解決策

この問題を解決するには、PHP コードで使用される認証方法を変更して一致させることができます。サーバーのデフォルト設定。あるいは、MySQL Server の ini ファイルを変更して、PHP コードと互換性のある認証プラグインを指定することもできます。以下に考えられる解決策をいくつか示します。

  • MySQL サーバーで mysql_native_password プラグインを有効にします。

    • MySQL サーバーの ini ファイルを開いて、「default_authentication_plugin」パラメータを見つけます。
    • 値を次のように変更します"mysql_native_password."
  • caching_sha2_password プラグインを使用するように PHP コードを変更します。

    • mysqli_options() 関数を使用して、MYSQLI_OPT_AUTH_PLUGIN オプションを次のように設定します。 "caching_sha2_password."

または、SQL コマンドを使用して MySQL ユーザーの認証方法を mysql_native_password に切り替えることもできます:

  • 既存のパスワードを変更ユーザー:

    • SQL コマンドを実行します: ALTER USER 'mysqlUsername'@'localhost' IDENTIFIED WITH mysql_native_password BY 'mysqlUsernamePassword';
  • 新規作成ユーザーとmysql_native_password:

    • SQL コマンドを実行します: CREATE USER 'jeffrey'@'localhost' IDENTIFIED WITH mysql_native_password BY 'password';

を実装することによりこれらのソリューションを使用すると、 MySQL サーバーと PHP クライアントで使用される認証方法を調整し、データベースへの接続を正常に確立できるようにします。

以上がPHP の「mysqli_connect: 認証方法がクライアントに不明です [caching_sha2_password]」エラーを修正する方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
著者別の最新記事
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート