nodejs连接mysql报错:Client does not support authentication protocol requested by server; consider upgrad

由于本人是前端,mysql只是偶尔做一下小项目会用到,大概一年没有用了。
今天用mac通过brew下载了一个8.0.12版本的mysql;然后用egg进行连接,egg是阿里封装的一个nodejs框架。
下载到本地的mysql;初始密码我是留空的。
所以在nodejs项目中配置mysql连接数据的时候我的password=’’;

结果报错了:

Client does not support authentication protocol requested by server; consider upgrad

我怀疑是MySQL密码的问题;于是我到网上找了很多种修改密码方法:

//开启mysql服务
mysql.server start
//进入mysql
mysql -u root -p
//修改密码方案1(错)
USE mysql SET PASSWORD FOR 'root'@'localhost' = OLD_PASSWORD('密码');
//修改密码方案2(错)
UPDATE mysql.user SET Password = OLD_PASSWORD('密码')WHERE Host = 'localhost' AND User = 'root';
//修改密码方案3(对)
USE mysql; 
ALTER USER 'root'@'localhost'IDENTIFIED WITH mysql_native_password BY '密码';
//重启
FLUSH PRIVILEGES;

修改密码后的nodejs项目的配置文件

client: {
      // host
      host: 'localhost',
      // 端口号
      port: '3306',
      // 用户名
      user: 'root',
      // 密码
      password: '123456',
      // 数据库名
      database: 'blog',
    },

最后用了方案3终于连接上了;记住你运行nodejs项目时一定要先将mysql的服务打开,不然也是连不上的。

  • 8
    点赞
  • 10
    收藏
    觉得还不错? 一键收藏
  • 4
    评论
Navicat是一款功能强大的数据库管理工具,可以于连接和管理各种类型的数据库。它支持多种数据库系统,包括MySQL、Oracle、SQL Server等。 要连接Node.js和MySQL数据库,你可以按照以下步骤进行操作: 1. 首先,确保你已经安装了Node.js和MySQL数据库,并且数据库已经正确配置和启动。 2. 在Node.js项目中,使用npm安装mysql模块,可以通过以下命令进行安装: ``` npm install mysql ``` 3. 在Node.js代码中,使用以下代码进行MySQL数据库的连接: ```javascript const mysql = require('mysql'); const connection = mysql.createConnection({ host: 'localhost', // 数据库主机名 user: 'root', // 数据库用户名 password: 'password', // 数据库密码 database: 'database_name' // 数据库名称 }); connection.connect((err) => { if (err) { console.error('Error connecting to MySQL database: ' + err.stack); return; } console.log('Connected to MySQL database as id ' + connection.threadId); }); ``` 请将上述代码中的`host`、`user`、`password`和`database_name`替换为你自己的数据库信息。 4. 运行Node.js代码,如果一切正常,你应该能够成功连接MySQL数据库。 关于你提到的连接报错"Client does not support authentication protocol requested by server",这是由于MySQL服务器使用了较新的身份验证插件,而Navicat连接工具使用的MySQL客户端版本较旧,不支持该身份验证插件导致的。解决这个问题的方法有两种: 1. 更新Navicat连接工具的版本,确保使用的是最新版本,以支持新的身份验证插件。 2. 在MySQL服务器上修改用户的身份验证方式,将其改为旧的身份验证插件。可以使用以下命令进行修改: ```sql ALTER USER 'username'@'localhost' IDENTIFIED WITH mysql_native_password BY 'password'; ``` 将上述命令中的`username`和`password`替换为你自己的用户名和密码。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值