我最初使用的是mysql 8.0,这给了我错误
ER_NOT_SUPPORTED_AUTH_MODE:客户端不支持服务器请求的身份验证协议。考虑升级MySQL客户端
在尝试运行我的服务器时。我在多个来源上看到降级到mysql@5.7可以解决问题,因为5.7使用本机密码身份验证,但是降级到较早版本后仍然存在相同的错误。为什么错误仍然存在,还有其他已知原因吗?
这是我的配置文件:
config.js
// import dependencies
const util = require("util");
const mysql = require("mysql");
// import environment variables
const env = {
env: process.env.NODE_ENV,
host: process.env.DB_HOST,
database: process.env.DB_NAME,
user: process.env.DB_USER,
password: process.env.DB_PASSWORD
}
const database = mysql.createConnection({
host: env.host,
database: env.database,
user: env.user,
password: env.password
});
database.connect(err => {
if (err) {
console.log("Connection " + err);
} else {
console.log(`Connection Success: You are now connected to the ${env.env} database`);
}
});
// promisify all database queries
database.query = util.promisify(database.query);
// export database
module.exports = database;
答案 0 :(得分:1)
MySQL 8.0引入了许多客户端不了解的默认SHA256加密。您有很多选择,最简单的方法是使用旧的MySQL本机密码(请参见https://mysqlserverteam.com/upgrading-to-mysql-8-0-default-authentication-plugin-considerations/)身份验证。更改帐户以使用较旧的身份验证,您的客户端连接器将很高兴。