婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁(yè) > 知識(shí)庫(kù) > 解決Node.js mysql客戶端不支持認(rèn)證協(xié)議引發(fā)的問(wèn)題

解決Node.js mysql客戶端不支持認(rèn)證協(xié)議引發(fā)的問(wèn)題

熱門標(biāo)簽:電話機(jī)器人的價(jià)格多少錢一個(gè)月 徐涇鎮(zhèn)騰訊地圖標(biāo)注 百度地圖標(biāo)注要什么軟件 福建外呼電銷機(jī)器人加盟 昌德訊外呼系統(tǒng) 400電話申請(qǐng)廠家現(xiàn)貨 中國(guó)地圖標(biāo)注公司 自己做地圖標(biāo)注需要些什么 天津公司外呼系統(tǒng)軟件

前言

mysql模塊(項(xiàng)目地址為https://github.com/mysqljs/mysql)是一個(gè)開(kāi)源的、JavaScript編寫(xiě)的MySQL驅(qū)動(dòng),可以在Node.js應(yīng)用中來(lái)操作MySQL。但在使用過(guò)程中,出現(xiàn)了“ER_NOT_SUPPORTED_AUTH_MODE”問(wèn)題。

本文介紹了出現(xiàn)該問(wèn)題的原因及解決方案。

報(bào)錯(cuò)信息

當(dāng)我試圖使用mysql模塊來(lái)連接MySQL 8時(shí),出現(xiàn)了如下錯(cuò)誤信息:

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

出錯(cuò)原因

導(dǎo)致這個(gè)錯(cuò)誤的原因是,目前,最新的mysql模塊并未完全支持MySQL 8的“caching_sha2_password”加密方式,而“caching_sha2_password”在MySQL 8中是默認(rèn)的加密方式。因此,下面的方式命令是默認(rèn)已經(jīng)使用了“caching_sha2_password”加密方式,該賬號(hào)、密碼無(wú)法在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)

上述語(yǔ)句,顯示指定了使用“mysql_native_password”的加密方式。這種方式是在mysql模塊能夠支持。

再此運(yùn)行應(yīng)用,可以看到如下的控制臺(tái)輸出信息:

$ node index.js
The result is: RowDataPacket { user_id: 1, username: '老衛(wèi)' }

其中,“RowDataPacket { user_id: 1, username: ‘老衛(wèi)' }”就是數(shù)據(jù)庫(kù)查詢的結(jié)果。

源碼

本節(jié)例子可以在https://github.com/waylau/nodejs-book-samples的“mysql-demo”應(yīng)用中找到。

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

您可能感興趣的文章:
  • MySQL mysqladmin客戶端的使用簡(jiǎn)介
  • MySQL 如何連接對(duì)應(yīng)的客戶端進(jìn)程
  • 解決MySql客戶端秒退問(wèn)題(找不到my.ini)
  • PHP Swoole異步MySQL客戶端實(shí)現(xiàn)方法示例
  • mysql8.0.11客戶端無(wú)法登陸的解決方法
  • mysql/Java服務(wù)端對(duì)emoji的支持與問(wèn)題解決方法詳解
  • 初識(shí)NodeJS服務(wù)端開(kāi)發(fā)入門(Express+MySQL)
  • 用于App服務(wù)端的MySQL連接池(支持高并發(fā))
  • 解讀MySQL的客戶端和服務(wù)端協(xié)議

標(biāo)簽:鄂爾多斯 北京 荊門 梅河口 陜西 駐馬店 昌都 黔西

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《解決Node.js mysql客戶端不支持認(rèn)證協(xié)議引發(fā)的問(wèn)題》,本文關(guān)鍵詞  解決,Node.js,mysql,客戶端,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問(wèn)題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無(wú)關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《解決Node.js mysql客戶端不支持認(rèn)證協(xié)議引發(fā)的問(wèn)題》相關(guān)的同類信息!
  • 本頁(yè)收集關(guān)于解決Node.js mysql客戶端不支持認(rèn)證協(xié)議引發(fā)的問(wèn)題的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    主站蜘蛛池模板: 普兰店市| 兴山县| 西华县| 建瓯市| 昆明市| 昌图县| 天津市| 苗栗县| 汾阳市| 田东县| 穆棱市| 安仁县| 金门县| 南岸区| 马公市| 炎陵县| 祁阳县| 偏关县| 建德市| 石阡县| 鄢陵县| 宝鸡市| 东阳市| 鄂伦春自治旗| 黔西| 广州市| 合肥市| 建宁县| 怀柔区| 金秀| 五河县| 巨鹿县| 重庆市| 桓台县| 韩城市| 栾川县| 葵青区| 佛山市| 丹江口市| 晴隆县| 修文县|