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

755

由于某些原因,我无法与服务器建立简单的连接。我使用默认设置安装了最新的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!");
    });

以下是在命令提示符中发现的错误:

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
es\mysql\lib\Connection.js:103:28)
    at Socket.emit (events.js:159:13)
    at addChunk (_stream_readable.js:265:12)
    at readableAddChunk (_stream_readable.js:252:11)
    at Socket.Readable.push (_stream_readable.js:209:10)
    --------------------
    at Protocol._enqueue (C:\Users\mysql-test\node_module
s\mysql\lib\protocol\Protocol.js:145:48)
    at Protocol.handshake (C:\Users\mysql-test\node_modul
es\mysql\lib\protocol\Protocol.js:52:23)
    at Connection.connect (C:\Users\mysql-test\node_modul
es\mysql\lib\Connection.js:130:18)
    at Object.<anonymous> (C:\Users\mysql-test\server.js:
11:5)
at Module._compile (module.js:660:30)
at Object.Module._extensions..js (module.js:671:10)
at Module.load (module.js:573:32)
at tryModuleLoad (module.js:513:12)
at Function.Module._load (module.js:505:3)
at Function.Module.runMain (module.js:701:10)

我已经阅读了一些内容,例如: https://dev.mysql.com/doc/refman/5.5/en/old-client.html https://github.com/mysqljs/mysql/issues/1507

但是我仍然不确定如何解决我的问题。


11
所有使用 SQLTools 扩展程序的 VS Code 用户,如果在使用过程中遇到问题,特别是在您刚刚升级了开发计算机上的 MySQL 实例时,请参考本文章。请注意,这篇文章旨在帮助您解决问题,因此请勿更改原文意思。 - OzzyTheGiant
我曾经遇到过相同的问题,因为我在连接时使用了3306端口,但是当我安装MySQL时,我将默认端口设置为了3307。所以请注意,这也可能是协议不匹配引起的。 - Stepan Rafael
你应该考虑将被接受的答案更改为Aidin的。 - Mike
MySQL 8版本目前尚未被Strapi支持。不过,官方博客文章提供了帮助您配置MySQL 8与Strapi的方法。请访问官方博客文章获取更多信息。 - Rubek Joshi
1
只需将您的npm包更新为mysql2 链接。更多详细信息请参见 SO答案。 - Lorraine R.
35个回答

0
UPDATE mysql.user SET authentication_string = PASSWORD('MY_NEW_PASSWORD')
WHERE User = 'root' AND Host = 'localhost';
FLUSH PRIVILEGES;

这对我有用。


-1

你应该使用与 MySQL 连接相同的模式来处理会话

(async () => {
    const connection = await db.connection();
    sessionStore = new MySQLStore({

    }, connection); //just pass your connection here 
})();

我只是把这个复制粘贴到这里,但你可能已经实现了类似的东西来处理你的查询

const mysql = require('mysql')

if (!process.env.NODE_ENV || process.env.NODE_ENV === 'development') {
    require('dotenv').config();
}

const dbConfig = {
    host: process.env.DB_HOST,
    user: process.env.DB_USER,
    password: process.env.DB_PASSWORD,
    database: process.env.DB_DATABASE,
    connectionLimit: process.env.DB_CONNECTION_LIMITS
}

const pool = mysql.createPool(dbConfig);

const connection = () => {
    return new Promise((resolve, reject) => {
        pool.getConnection((err, connection) => {
            if (err) {
                reject(err);
            }

            const query = (sql, binding) => {
                return new Promise((resolve, reject) => {
                    connection.query(sql, binding, (err, result) => {
                        if (err) {
                            reject(err);
                        }
                        resolve(result);
                    });
                });
            };

            const release = () => {
                return new Promise((resolve, reject) => {
                    if (err) {
                        reject(err);
                    }
                    resolve(connection.release());
                });
            };
            resolve({ query, release });
        });
    });
};

const query = (sql, binding) => {
    return new Promise((resolve, reject) => {
        pool.query(sql, binding, (err, result, fields) => {
            if (err) {
                reject(err);
            }
            resolve(result);
        });
    });
};

module.exports = { pool, connection, query };


-1
只需运行MySQL服务器安装程序并重新配置MySQL服务器...这对我有用。

-3

我在使用MySQL时遇到了同样的问题,我通过使用XAMPP连接MySQL并停止Windows中MySQL的服务(控制面板-管理工具-服务),并在负责数据库的db.js文件夹中将密码设置为空(您可以在此处查看:)解决了这个问题。

const mysql = require('mysql');
const connection = mysql.createConnection({
  host: 'localhost',
  user: 'root',
  password: ''
});

1
请翻译以下与编程有关的内容,从英文到中文。只返回翻译后的文本:请不要把你遇到的问题作为回答问题的原因。 - Aloy A Sen
不要使用 root 连接到您的数据库。创建另一个用户,授予所需的权限,然后使用它! - Maf

-3

确保用于访问数据库的用户具有执行此操作的特权。
GRANT ALL PRIVILEGES ON * . * TO 'user'@'localhost';
其中第一个星号可以替换为数据库名称,第二个星号指定表格。记得在之后刷新特权。


不应使用超过权限的用户。为用户提供其工作所需的权限,而不要超过其所需。 - philraj

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接