Node.js mysqlクライアントが認証プロトコルをサポートしていない問題を解決する

Node.js mysqlクライアントが認証プロトコルをサポートしていない問題を解決する

序文

mysql モジュール (プロジェクト アドレスは https://github.com/mysqljs/mysql) は、Node.js アプリケーションで MySQL を操作できる JavaScript で記述されたオープン ソースの MySQL ドライバーです。しかし、使用中に「ER_NOT_SUPPORTED_AUTH_MODE」問題が発生しました。

この記事では、この問題の原因と解決策について説明します。

エラーメッセージ

mysql モジュールを使用して MySQL 8 に接続しようとすると、次のエラー メッセージが表示されます。

D:\workspaceGithub\nodejs-book-sa​​mples\samples\mysql-demo\index.js:17
エラーをスローします。
^
エラー: ER_NOT_SUPPORTED_AUTH_MODE: クライアントはサーバーが要求した認証プロトコルをサポートしていません。MySQL クライアントのアップグレードを検討してください。
Handshake.Sequence._packetToError (D:\workspaceGithub\nodejs-book-sa​​mples\samples\mysql-demo\node_modules\mysql\lib\protocol\sequences\Sequence.js:47:14) で
Handshake.ErrorPacket (D:\workspaceGithub\nodejs-book-sa​​mples\samples\mysql-demo\node_modules\mysql\lib\protocol\sequences\Handshake.js:123:18) で
Protocol._parsePacket (D:\workspaceGithub\nodejs-book-sa​​mples\samples\mysql-demo\node_modules\mysql\lib\protocol\Protocol.js:291:23) で
Parser._parsePacket (D:\workspaceGithub\nodejs-book-sa​​mples\samples\mysql-demo\node_modules\mysql\lib\protocol\Parser.js:433:10) で
Parser.write (D:\workspaceGithub\nodejs-book-sa​​mples\samples\mysql-demo\node_modules\mysql\lib\protocol\Parser.js:43:10) で
Protocol.write (D:\workspaceGithub\nodejs-book-sa​​mples\samples\mysql-demo\node_modules\mysql\lib\protocol\Protocol.js:38:16) で
Socket.<anonymous> (D:\workspaceGithub\nodejs-book-sa​​mples\samples\mysql-demo\node_modules\mysql\lib\Connection.js:91:28) で
Socket.<anonymous> (D:\workspaceGithub\nodejs-book-sa​​mples\samples\mysql-demo\node_modules\mysql\lib\Connection.js:525:10) で
Socket.emit (events.js:196:13) で
addChunk で (_stream_readable.js:290:12)
--------------------
Protocol._enqueue (D:\workspaceGithub\nodejs-book-sa​​mples\samples\mysql-demo\node_modules\mysql\lib\protocol\Protocol.js:144:48) で
Protocol.handshake (D:\workspaceGithub\nodejs-book-sa​​mples\samples\mysql-demo\node_modules\mysql\lib\protocol\Protocol.js:51:23) で
Connection.connect (D:\workspaceGithub\nodejs-book-sa​​mples\samples\mysql-demo\node_modules\mysql\lib\Connection.js:119:18) で
オブジェクト.<匿名> (D:\workspaceGithub\nodejs-book-sa​​mples\samples\mysql-demo\index.js:12:12)
Module._compile (internal/modules/cjs/loader.js:759:30) で
Object.Module._extensions..js (internal/modules/cjs/loader.js:770:10) で
Module.load (internal/modules/cjs/loader.js:628:32) で
Function.Module._load (internal/modules/cjs/loader.js:555:12) で
Function.Module.runMain (internal/modules/cjs/loader.js:826:10) で
internal/main/run_main_module.js:17:11 で

エラーの原因

このエラーが発生する理由は、現在、最新の MySQL モジュールが MySQL 8 の「caching_sha2_password」暗号化方式を完全にサポートしておらず、「caching_sha2_password」が MySQL 8 のデフォルトの暗号化方式であるためです。そのため、以下のコマンドではデフォルトで「caching_sha2_password」暗号化方式が使用され、アカウントとパスワードはmysqlモジュールで使用できなくなります。

mysql> ALTER USER 'root'@'localhost' が '123456' によって識別されます。
クエリは正常、影響を受けた行は 0 行 (0.12 秒)

回避策

解決策は、ユーザー root のパスワードを変更し、mysql モジュールがサポートできる暗号化方法を指定することです。

mysql> ALTER USER 'root'@'localhost' が mysql_native_password によって '123456' で識別されます。
クエリは正常、影響を受けた行は 0 行 (0.12 秒)

上記の文は、「mysql_native_password」を使用した暗号化方式が指定されていることを示しています。このメソッドは、mysql モジュールによってサポートされています。

アプリケーションを再度実行すると、次のコンソール出力が表示されます。

$ ノードindex.js
結果は次のとおりです: RowDataPacket { user_id: 1, username: '老卫' }

このうち、「RowDataPacket { user_id: 1, username: '老卫' }」はデータベースクエリの結果です。

ソースコード

このセクションの例は、https://github.com/waylau/nodejs-book-sa​​mples の「mysql-demo」アプリケーションにあります。

以上がこの記事の全内容です。皆様の勉強のお役に立てれば幸いです。また、123WORDPRESS.COM を応援していただければ幸いです。

以下もご興味があるかもしれません:
  • MySQL mysqladmin クライアントの使用の概要
  • MySQL は対応するクライアント プロセスにどのように接続しますか?
  • MySql クライアントが数秒で終了する問題を解決する (my.ini が見つからない)
  • PHP Swoole 非同期 MySQL クライアント実装例
  • mysql8.0.11クライアントがログインできない問題の解決方法
  • 絵文字と問題解決のためのMySQL/Javaサーバーサポートの詳細な説明
  • NodeJS サーバー開発入門 (Express+MySQL)
  • アプリケーション サーバー用の MySQL 接続プール (高い同時実行性をサポート)
  • MySQLクライアントとサーバーのプロトコルの解釈

<<:  WeChatアプレットはシンプルな手書き署名コンポーネントを実装します

>>:  nginx ベースのブラウザネゴシエーションキャッシュプロセスの詳細な説明

推薦する

Reactは複雑な検索フォームの展開と折りたたみ機能を実装します

時間に余裕を持って、過去を忘れましょう。前のセクションでは、[検索] フォームとクエリおよびリセット...

ZabbixはPSK共有キーを使用してサーバーとエージェント間の通信を暗号化します。

Zabbix バージョン 3.0 以降、Zabbix サーバー、Zabbix プロキシ、Zabbi...

Vueはシンプルな計算機能を実装します

この記事では、参考までに、Vue の具体的なコードで簡単な計算機を実装する方法を紹介します。具体的な...

MySQL コピーテーブルと許可分析の 3 つの実装方法

テーブルを素早くコピーする方法まず、テーブル db1.t を作成し、1000 行のデータを挿入します...

Nginx Webサーバーのサンプルコードの設定方法の詳細な説明

概要今日は主に、NGINX を Web サーバーとして設定する方法を共有します。内容は次のとおりです...

CSS background-blend-modeの仕組みを深く理解する

この記事は共有および集約することを歓迎します。全文を転載する必要はありません。著作権を尊重してくださ...

JavaScript の例におけるループの使用法の詳細な説明

退屈だったので、ループに関する簡単な演習をいくつかまとめてみました。JS を学び始めたばかりの方に役...

Linux でプロセスを隠す方法と、遭遇する落とし穴

序文1. この記事で使用したツールは、https://github.com/gianlucabore...

Linux 論理ボリューム管理 (LVM) の使用法の概要

ディスク領域の管理は、システム管理者にとって重要な日常的なタスクです。ディスク領域が使い果たされると...

Vueの監視プロパティの詳細

目次1.watchは一般的なデータ(数値、文字列、ブール値)の変更を監視します。 1. 数値2. 文...

CSS3 疑似クラスセレクターの簡単なレビュー

序文CSS がフロントエンド開発の基本的なスキルであるならば、「セレクター」は基礎中の基礎です。これ...

ファイアウォールルールの設定とコマンド(ホワイトリスト設定)の詳しい説明

1. ファイアウォールルールを設定する例1: ポート8080を外部に公開する ファイアウォールコマン...

MySQL 8.0.22 winx64 のインストールと設定方法のグラフィックチュートリアル

MySQL-8.0.22-winx64のデータベースインストールチュートリアルは参考になります。具体...

jsでの位置計算を徹底的に理解するのに役立つ記事

目次導入スクロール要素.スクロール()要素.scrollHeight/scrollWidth要素.s...

Windows に Docker をインストールする詳細なチュートリアル

ローカルの MySQL バージョンが比較的低いため、最近 MySQL のバージョンをアップグレードす...