MySQL 8.0 - Client does not support authentication protocol requested by server....

本文详细介绍了在使用Node.js连接MySQL数据库时遇到的ER_NOT_SUPPORTED_AUTH_MODE错误,并提供了有效的解决方案,包括更新用户身份验证方式和刷新权限。

我在用 MySQL数据库 连接 node.Js 的时候,发生的错误:

const mysql = require('mysql')

// 创建连接对象
const con = mysql.createConnection({
    host: 'localhost',
    user: 'root',
    password: '123456',
    database: 'myblog'
})

// 开始连接
con.connect()

// 执行 sql 语句
const sql = `update users set realname="李四2" where username="lisi";`
con.query(sql, (err, result) => {
    if (err) {
        console.error(err)
        return
    }
    console.log(result)
})

// 关闭连接
con.end()

报的大致的错误:

 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-

解决方案:

  1. 如果你有 MYSQL Workbench 的话, 可以直接在里面使用 如下的命令: (注意你的表操作行为)
1.ALTER USER 'root'@'localhost' IDENTIFIED WITH mysql_native_password BY 'YourRootPassword';
-- or
CREATE USER 'foo'@'%' IDENTIFIED WITH mysql_native_password BY 'bar';
-- then
FLUSH PRIVILEGES;

2.你可以打开 mysql 自带的命令行工具 或者 命令行:

$ mysql -u root -p
Enter password: (enter your root password)
mysql> ALTER USER 'root'@'localhost' IDENTIFIED WITH mysql_native_password BY 'your_new_password';
mysql> FLUSH PRIVILEGES;
mysql> quit

到这里你可以重新启动的服务,你就会看你的数据库正在连接成功。

转载于:https://my.oschina.net/u/3520255/blog/3033878

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值