ホームページ >データベース >mysql チュートリアル >Node.js アプリが MySQL 8.0 での認証に失敗するのはなぜですか?

Node.js アプリが MySQL 8.0 での認証に失敗するのはなぜですか?

Susan Sarandon
Susan Sarandonオリジナル
2024-11-30 14:29:14258ブラウズ

Why is My Node.js App Failing to Authenticate with MySQL 8.0?

MySQL 8.0 での Node.js 認証の問題

Node.js を使用して root アカウントで MySQL データベースに接続しようとすると、特定の問題が生じる可能性があります。これは、デフォルトの認証プラグインが mysql_native_password から caching_sha2_password に変更された MySQL 8.0 に特に関係します。

エラー メッセージと原因

Node.js アプリケーションを使用して MySQL 8.0 に接続しようとすると、次のエラーが発生する可能性があります:

ER_NOT_SUPPORTED_AUTH_MODE: Client does not support authentication protocol requested by server; consider upgrading MySQL client

Thisこのエラーは、Node.js MySQL ドライバーが MySQL 8.0 で導入された新しい認証プラグインを使用できないことを示しています。

回避策:

問題を解決し、root アカウントを使用して MySQL 8.0 に接続するには、次のようにします。 mysql_native_password プラグインは、デフォルトの caching_sha2_password の代わりに使用できます。これは、次のいずれかの方法で実行できます:

  1. 既存の root アカウントを変更します:
ALTER USER 'root'@'localhost' IDENTIFIED WITH mysql_native_password BY 'MyNewPass';
  1. 目的のプラグインを使用して新しいユーザーを作成します:
CREATE USER 'foo'@'localhost' IDENTIFIED WITH mysql_native_password BY 'bar';

代替解決策:

代わりに、X プロトコルに基づく公式の MySQL Node.js コネクタを利用することもできます。このコネクタは、MySQL 8.0 の新しい認証モードをサポートします。

以上がNode.js アプリが MySQL 8.0 での認証に失敗するのはなぜですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

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