相关疑难解决方法(0)

MySQL 8.0 - 客户端不支持服务器请求的身份验证协议; 考虑升级MySQL客户端

我是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 node.js

165
推荐指数
17
解决办法
18万
查看次数

MySQL 8:ER_NOT_SUPPORTED_AUTH_MODE

设置

  • Expressjs(节点)在Windows 10 PC 上的localhost:3000上运行。
  • MySQL 通过docker-machine在 192.168.99.100:3306 的 Docker 容器中运行。

问题

尝试使用以下方法将服务器连接到 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 node.js

7
推荐指数
1
解决办法
6256
查看次数

NodeJS MySQL客户端不支持身份验证协议

当我尝试与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)

mysql database backend node.js

5
推荐指数
2
解决办法
1万
查看次数

如何在外部为 MySQL 创建密码哈希?

我曾经能够通过 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)我的密码进行哈希处理,但现在这甚至不是一个选择。

mysql node.js mysql-8.0

4
推荐指数
2
解决办法
5620
查看次数

ER_NOT_SUPPORTED_AUTH_MODE:客户端不支持服务器请求的身份验证协议。考虑升级MySQL客户端

在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客户端

mysql node.js

1
推荐指数
3
解决办法
6743
查看次数

标签 统计

mysql ×5

node.js ×5

backend ×1

database ×1

mysql-8.0 ×1