我是node.js和MySQL初学者,我刚开始设置并尝试一些基本代码.但是,由于某种原因,我甚至无法与服务器建立简单的连接.我使用默认设置安装最新的MySQL Community 8.0数据库和Node.JS.
这是我的node.js代码
var mysql = require('mysql');
var con = mysql.createConnection({
host: "localhost",
user: "root",
password: "password",
insecureAuth : true
});
con.connect(function(err) {
if (err) throw err;
console.log("Connected!");
});
Run Code Online (Sandbox Code Playgroud)
以下是命令提示符中发现的错误:
C:\Users\mysql-test>node app.js
C:\Users\mysql-test\node_modules\mysql\lib\protocol\Parse
r.js:80
throw err; // Rethrow non-MySQL errors
^
Error: ER_NOT_SUPPORTED_AUTH_MODE: Client does not support authentication protocol requested by server; consider upgrading MySQL client
at Handshake.Sequence._packetToError (C:\Users\mysql-
test\node_modules\mysql\lib\protocol\sequences\Sequence.js:52:14)
at Handshake.ErrorPacket (C:\Users\mysql-test\node_mo
dules\mysql\lib\protocol\sequences\Handshake.js:130:18)
at Protocol._parsePacket (C:\Users\mysql-test\node_mo
dules\mysql\lib\protocol\Protocol.js:279:23)
at Parser.write (C:\Users\mysql-test\node_modules\mys
ql\lib\protocol\Parser.js:76:12)
at Protocol.write (C:\Users\mysql-test\node_modules\m
ysql\lib\protocol\Protocol.js:39:16)
at Socket.<anonymous> (C:\Users\mysql-test\node_modul …Run Code Online (Sandbox Code Playgroud) 尝试使用以下方法将服务器连接到 MySQL 时:
const connection = mysql.createConnection({
host: '192.168.99.100',
user: 'root',
password: 'foo123',
database: 'foo_db'
});
Run Code Online (Sandbox Code Playgroud)
获得:
错误:ER_NOT_SUPPORTED_AUTH_MODE:客户端不支持服务器请求的认证协议;考虑升级 MySQL 客户端
在 StackOverflow 上检查了很多答案。他们中的大多数使用(示例):
ALTER USER 'root'@'localhost' IDENTIFIED WITH mysql_native_password BY 'MyNewPass';
Run Code Online (Sandbox Code Playgroud)
但是我得到:
mysql> ALTER USER 'root'@'localhost' IDENTIFIED WITH mysql_native_password BY 'MyNewPass'; 查询正常,0 行受影响(0.06 秒)
而服务器仍然不想连接。使用 MySQL 5.7 工作正常。
任何想法如何为 MySQL 8 解决这个问题?
添加:
只是要清楚:
当我尝试与mysql 8.0连接时,出现此错误。我怎样才能解决这个问题 ?
code: 'ER_NOT_SUPPORTED_AUTH_MODE',
errno: 1251,
sqlMessage: 'Client does not support authentication protocol requested by server;
consider upgrading MySQL client',
sqlState: '08004',
fatal: true
Run Code Online (Sandbox Code Playgroud) 我曾经能够通过 sha1 运行密码两次来创建与 MySQL 兼容的密码,但似乎这在 MySQL 8 中不起作用。
MySQL现在似乎使用这些密码插件。语法如下(在 JS 中):
const createUserSql = `CREATE USER ${db.escapeValue(agency.login)} IDENTIFIED WITH mysql_native_password BY ${db.escapeValue(passwordHash)};`;
Run Code Online (Sandbox Code Playgroud)
我想在 Node.js 中创建可与 MySQL 一起使用的密码。我知道我可以只使用纯文本密码并让 MySQL 对它们进行哈希处理,但我将此 SQL 打印到终端,并且我不希望密码可见,因此我想对它们进行预哈希处理。
什么算法适用于 MySQL 8?我愿意使用任何内置密码插件。
sha256_password听起来不错,但我不认为它是一个直接的 sha256 哈希,听起来它内置了一个盐,所以我不确定如何在 Node.js 中创建一个。
MySQL的PASSWORD()功能也没有了。我真的不想对SELECT PASSWORD(:plainTextPass)我的密码进行哈希处理,但现在这甚至不是一个选择。
在nodejs中使用的mysql问题
const mysql = require('mysql');
var connection = mysql.createConnection({
host : 'localhost',
user : 'root',
password : '123456789',
database : 'userdata'
});
connection.connect(function(err) {
if (err) {
console.error('error connecting: ' + err);
return;
}
console.log('connected as id ' + connection.threadId);
});
Run Code Online (Sandbox Code Playgroud)
错误:ER_NOT_SUPPORTED_AUTH_MODE:客户端不支持服务器请求的身份验证协议。考虑升级MySQL客户端