【问题标题】:Cannot connect to MySQL Database on Node.js无法连接到 Node.js 上的 MySQL 数据库
【发布时间】:2017-08-29 20:08:06
【问题描述】:

我仍然无法弄清楚为什么在尝试连接到 Node.js 上的 MYSQL 服务器时仍然收到此错误消息 -

错误 -

Error: ER_ACCESS_DENIED_ERROR: Access denied for user 'root'@'localhost' (using password: YES)
at Handshake.Sequence._packetToError (C:\Users\Admin\Desktop\Test Files\Hello World!\node_modules\mysql\lib\protocol\sequences\Sequence.js:52:14)
at Handshake.ErrorPacket (C:\Users\Admin\Desktop\Test Files\Hello World!\node_modules\mysql\lib\protocol\sequences\Handshake.js:103:18)
at Protocol._parsePacket (C:\Users\Admin\Desktop\Test Files\Hello World!\node_modules\mysql\lib\protocol\Protocol.js:279:23)
at Parser.write (C:\Users\Admin\Desktop\Test Files\Hello World!\node_modules\mysql\lib\protocol\Parser.js:76:12)
at Protocol.write (C:\Users\Admin\Desktop\Test Files\Hello World!\node_modules\mysql\lib\protocol\Protocol.js:39:16)
at Socket.<anonymous> (C:\Users\Admin\Desktop\Test Files\Hello World!\node_modules\mysql\lib\Connection.js:103:28)
at emitOne (events.js:115:13)
at Socket.emit (events.js:210:7)
at addChunk (_stream_readable.js:266:12)
at readableAddChunk (_stream_readable.js:253:11)

JS -

var mysql = require('mysql');
var con = mysql.createConnection({
    host: 'localhost', 
    user: 'root', 
    password: '*****', 
    database: 'mydb'
    });

con.connect(function(err) {
    if (err) throw err;
    console.log("Connected!");
});

【问题讨论】:

  • 你在使用 XAMPP 服务器吗?
  • 访问被拒绝通常意味着您使用了错误的密码。
  • 试试this
  • @ChristianLuneborg 尝试提及 DB name ,例如。 database: 'test' 并重新启动 XAMPP 或在 mysql 上执行 flush host;
  • @ChristianLuneborg 您刚刚更新了有问题的代码,但您在密码后错过了,。这个错字是在这里还是在代码中漏掉了:)?

标签: mysql node.js


【解决方案1】:

你的 node.js 没有问题

node.js 只需要安装 mysql

->在命令提示符下进入nodejs的安装,输入

 npm install mysql 

在 Eclipse 中: 1)安装nodejs插件 2)在nodejs项目中打开package.json,进入

       "author": "Krish",
       "dependencies": {
                "mysql": "2.x.x"
      },

3) right click on the project run -> node install

它将安装 mysql 并准备好连接数据库

ER_ACCESS_DENIED_ERROR

1) 转到 mysql 命令提示符

   mysql> create user 'root'@localhost IDENTIFIED BY 'password';

2) 给予许可

   mysql> GRANT ALL PRIVILEGES ON *.* TO 'root'@'localhost' WITH GRANT 
        OPTION;

   mysql>SHOW GRANTS FOR 'root'@'localhost';

现在你可以运行你的 JS 了。它将被连接

【讨论】:

    【解决方案2】:

    如果您在 xampp 中托管 SQL,则 localhost 中的 root 用户没有任何密码,因此请删除密码。

    它对我有用。

    【讨论】:

      猜你喜欢
      • 2014-11-25
      • 2016-03-22
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 2016-12-03
      相关资源
      最近更新 更多