Node使用Express中的mysql连接mysql8失败(原因及解决)

4 篇文章 0 订阅
1 篇文章 0 订阅

系统环境

widows10,
node 16.13.2,
mysql8.0.28,

遇到的问题

我的node代码:

// 导入myslq模块
const mysql = require('mysql')
// 建立mysql的连接
const db = mysql.createPool({
  host: '127.0.0.1',
  user: 'root',
  password: '123456',
  database: 'my_db_01',
})

db.query('select 1', (err, results) => {
  if(err) return console.log(err)
  console.log(results)
})

控制台报错, 最后几行内容为:

  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

报错原因

mysql8更换了新的密码验证方式, 我们的node客户端不支持新的验证方式

解决办法

方法1: 将mysql密码验证降级 (个人使用时推荐)

优点: 简单
缺点: 数据库不安全

登录mysql, 并运行一下代码, 务必记得执行第二句

mysql> alter user 'root'@'localhost' identified with mysql_native_password by '123456';
Query OK, 0 rows affected (0.27 sec)

mysql> flush privileges;
Query OK, 0 rows affected (0.08 sec)
方法2: 使用新版mysql连接器(企业推荐)

优点: 简单
缺点: 可能有些方法发生了变动
删除旧连接器, 使用新连接器. 项目的控制台输入:

npm un mysql && npm i mysql2

然后在js代码中修改引入文件为:

// 导入myslq模块
const mysql = require('mysql2')
  • 5
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 6
    评论
评论 6
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值