当前位置: 移动技术网 > IT编程>数据库>Mysql > 解决Node.js mysql客户端不支持认证协议引发的问题

解决Node.js mysql客户端不支持认证协议引发的问题

2019年07月18日  | 移动技术网IT编程  | 我要评论
前言 mysql模块(项目地址为)是一个开源的、javascript编写的mysql驱动,可以在node.js应用中来操作mysql。但在使用过程中,出现了“er_not

前言

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: ‘老卫' }”就是数据库查询的结果。

源码

本节例子可以在的“mysql-demo”应用中找到。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持移动技术网。

如您对本文有疑问或者有任何想说的,请点击进行留言回复,万千网友为您解惑!

相关文章:

验证码:
移动技术网