加入收藏 | 设为首页 | 会员中心 | 我要投稿 云计算网_泰州站长网 (http://www.0523zz.com/)- 视觉智能、AI应用、CDN、行业物联网、智能数字人!
当前位置: 首页 > 站长学院 > MySql教程 > 正文

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

发布时间:2022-03-21 03:11:19 所属栏目:MySql教程 来源:互联网
导读:mysql模块(项目地址为https://github.com/mysqljs/mysql)是一个开源的、JavaScript编写的MySQL驱动,可以在Node.js应用中来操作MySQL。但在使用过程中,出现了ER_NOT_SUPPORTED_AUTH_MODE问题。 本文介绍了出现该问题的原因及解决方案。 报错信息 当我试
      mysql模块(项目地址为https://github.com/mysqljs/mysql)是一个开源的、JavaScript编写的MySQL驱动,可以在Node.js应用中来操作MySQL。但在使用过程中,出现了“ER_NOT_SUPPORTED_AUTH_MODE”问题。
 
     本文介绍了出现该问题的原因及解决方案。
 
      报错信息
     当我试图使用mysql模块来连接MySQL 8时,出现了如下错误信息:
 
D:workspaceGithubnodejs-book-samplessamplesmysql-demoindex.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:workspaceGithubnodejs-book-samplessamplesmysql-demonode_modulesmysqllibprotocolsequencesSequence.js:47:14)
at Handshake.ErrorPacket (D:workspaceGithubnodejs-book-samplessamplesmysql-demonode_modulesmysqllibprotocolsequencesHandshake.js:123:18)
at Protocol._parsePacket (D:workspaceGithubnodejs-book-samplessamplesmysql-demonode_modulesmysqllibprotocolProtocol.js:291:23)
at Parser._parsePacket (D:workspaceGithubnodejs-book-samplessamplesmysql-demonode_modulesmysqllibprotocolParser.js:433:10)
at Parser.write (D:workspaceGithubnodejs-book-samplessamplesmysql-demonode_modulesmysqllibprotocolParser.js:43:10)
at Protocol.write (D:workspaceGithubnodejs-book-samplessamplesmysql-demonode_modulesmysqllibprotocolProtocol.js:38:16)
at Socket.<anonymous> (D:workspaceGithubnodejs-book-samplessamplesmysql-demonode_modulesmysqllibConnection.js:91:28)
at Socket.<anonymous> (D:workspaceGithubnodejs-book-samplessamplesmysql-demonode_modulesmysqllibConnection.js:525:10)
at Socket.emit (events.js:196:13)
at addChunk (_stream_readable.js:290:12)
--------------------
at Protocol._enqueue (D:workspaceGithubnodejs-book-samplessamplesmysql-demonode_modulesmysqllibprotocolProtocol.js:144:48)
at Protocol.handshake (D:workspaceGithubnodejs-book-samplessamplesmysql-demonode_modulesmysqllibprotocolProtocol.js:51:23)
at Connection.connect (D:workspaceGithubnodejs-book-samplessamplesmysql-demonode_modulesmysqllibConnection.js:119:18)
at Object.<anonymous> (D:workspaceGithubnodejs-book-samplessamplesmysql-demoindex.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: ‘老卫' }”就是数据库查询的结果。
 
以上就是本文的全部内容,希望对大家的学习有所帮助。

(编辑:云计算网_泰州站长网)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    热点阅读