解决Node.js mysql客户端不支持认证协议引发的问题
作者:Way Lau 时间:2024-01-23 18:16:13
前言
mysql模块(项目地址为https://github.com/mysqljs/mysql)是一个开源的、JavaScript编写的MySQL驱动,可以在Node.js应用中来操作MySQL。但在使用过程中,出现了“ER_NOT_SUPPORTED_AUTH_MODE”问题。
本文介绍了出现该问题的原因及解决方案。
报错信息
当我试图使用mysql模块来连接MySQL 8时,出现了如下错误信息:
D:\workspaceGithub\nodejs-book-samples\samples\mysql-demo\index.js:17
throw error;
^
Error: ER_NOT_SUPPORTED_AUTH_MODE: Client does not support authentication protocol requested by server; consider upgrading MySQL client
at Handshake.Sequence._packetToError (D:\workspaceGithub\nodejs-book-samples\samples\mysql-demo\node_modules\mysql\lib\protocol\sequences\Sequence.js:47:14)
at Handshake.ErrorPacket (D:\workspaceGithub\nodejs-book-samples\samples\mysql-demo\node_modules\mysql\lib\protocol\sequences\Handshake.js:123:18)
at Protocol._parsePacket (D:\workspaceGithub\nodejs-book-samples\samples\mysql-demo\node_modules\mysql\lib\protocol\Protocol.js:291:23)
at Parser._parsePacket (D:\workspaceGithub\nodejs-book-samples\samples\mysql-demo\node_modules\mysql\lib\protocol\Parser.js:433:10)
at Parser.write (D:\workspaceGithub\nodejs-book-samples\samples\mysql-demo\node_modules\mysql\lib\protocol\Parser.js:43:10)
at Protocol.write (D:\workspaceGithub\nodejs-book-samples\samples\mysql-demo\node_modules\mysql\lib\protocol\Protocol.js:38:16)
at Socket.<anonymous> (D:\workspaceGithub\nodejs-book-samples\samples\mysql-demo\node_modules\mysql\lib\Connection.js:91:28)
at Socket.<anonymous> (D:\workspaceGithub\nodejs-book-samples\samples\mysql-demo\node_modules\mysql\lib\Connection.js:525:10)
at Socket.emit (events.js:196:13)
at addChunk (_stream_readable.js:290:12)
--------------------
at Protocol._enqueue (D:\workspaceGithub\nodejs-book-samples\samples\mysql-demo\node_modules\mysql\lib\protocol\Protocol.js:144:48)
at Protocol.handshake (D:\workspaceGithub\nodejs-book-samples\samples\mysql-demo\node_modules\mysql\lib\protocol\Protocol.js:51:23)
at Connection.connect (D:\workspaceGithub\nodejs-book-samples\samples\mysql-demo\node_modules\mysql\lib\Connection.js:119:18)
at Object.<anonymous> (D:\workspaceGithub\nodejs-book-samples\samples\mysql-demo\index.js:12:12)
at Module._compile (internal/modules/cjs/loader.js:759:30)
at Object.Module._extensions..js (internal/modules/cjs/loader.js:770:10)
at Module.load (internal/modules/cjs/loader.js:628:32)
at Function.Module._load (internal/modules/cjs/loader.js:555:12)
at Function.Module.runMain (internal/modules/cjs/loader.js:826:10)
at 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' IDENTIFIED BY '123456';
Query OK, 0 rows affected (0.12 sec)
解决方法
解决方法是从新修改用户root的密码,并指定mysql模块能够支持的加密方式:
mysql> ALTER USER 'root'@'localhost' IDENTIFIED WITH mysql_native_password BY '123456';
Query OK, 0 rows affected (0.12 sec)
上述语句,显示指定了使用“mysql_native_password”的加密方式。这种方式是在mysql模块能够支持。
再此运行应用,可以看到如下的控制台输出信息:
$ node index.js
The result is: RowDataPacket { user_id: 1, username: '老卫' }
其中,“RowDataPacket { user_id: 1, username: ‘老卫' }”就是数据库查询的结果。
源码
本节例子可以在https://github.com/waylau/nodejs-book-samples的“mysql-demo”应用中找到。
来源:https://waylau.com/node.js-mysql-client-does-not-support-authentication-protocol/
![](/images/zang.png)
![](/images/jiucuo.png)
猜你喜欢
在PHP中读取和写入WORD文档的代码
Python 异步等待任务集合
django框架使用方法详解
![](https://img.aspxhome.com/file/2023/0/99590_0s.png)
详解Python实现图像分割增强的两种方法
深入Golang的接口interface
![](https://img.aspxhome.com/file/2023/8/109758_0s.webp)
jQuery代码的14条改善技巧[译]
![](https://img.aspxhome.com/file/UploadPic/200912/2/01-56s.jpg)
[译]Javascript风格要素(一)
Go语言中日期包(time包)的具体使用
![](https://img.aspxhome.com/file/2023/1/127361_0s.jpg)
js选取多个或单个元素的实现代码(用class)
ASP中的Debug类--VBScript
MySQL基本增删改查语句练习(最新推荐)
![](https://img.aspxhome.com/file/2023/3/115583_0s.png)
Python对象循环引用垃圾回收算法详情
![](https://img.aspxhome.com/file/2023/6/77706_0s.png)
用python处理图片之打开\\显示\\保存图像的方法
![](https://img.aspxhome.com/file/2023/6/98786_0s.jpg)
Pycharm 安装 idea VIM插件的图文教程详解
![](https://img.aspxhome.com/file/2023/0/65530_0s.jpg)
Python生成二维码的教程详解
![](https://img.aspxhome.com/file/2023/9/128319_0s.png)
一文带你吃透Python中的日期时间模块
![](https://img.aspxhome.com/file/2023/0/103670_0s.png)
如何做一个文本书写器?
asp如何正确理解和使用Command、Connection和 Recordset三个对象?
基于python实现百度语音识别和图灵对话
![](https://img.aspxhome.com/file/2023/9/131229_0s.png)
浅谈MySQL timestamp(3)问题
![](https://img.aspxhome.com/file/2023/9/105679_0s.png)