Mysql 错误 - 1251 'ER_NOT_SUPPORTED_AUTH_MODE'

问题描述 投票:0回答:2

我知道这个问题已经在 SO 中得到了回答,但建议的修复对我不起作用!

错误:

      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:\Dev\Programmierung\FitnessAppExpo\node_modules\mysql\lib\protocol\sequences\Sequence.js:47:14)
    at Handshake.ErrorPacket (C:\Dev\Programmierung\FitnessAppExpo\node_modules\mysql\lib\protocol\sequences\Handshake.js:123:18)
    at Protocol._parsePacket (C:\Dev\Programmierung\FitnessAppExpo\node_modules\mysql\lib\protocol\Protocol.js:291:23)
    at Parser._parsePacket (C:\Dev\Programmierung\FitnessAppExpo\node_modules\mysql\lib\protocol\Parser.js:433:10)
    at Parser.write (C:\Dev\Programmierung\FitnessAppExpo\node_modules\mysql\lib\protocol\Parser.js:43:10)
    at Protocol.write (C:\Dev\Programmierung\FitnessAppExpo\node_modules\mysql\lib\protocol\Protocol.js:38:16)
    at Socket.<anonymous> (C:\Dev\Programmierung\FitnessAppExpo\node_modules\mysql\lib\Connection.js:88:28)
    at Socket.<anonymous> (C:\Dev\Programmierung\FitnessAppExpo\node_modules\mysql\lib\Connection.js:526:10)
    at Socket.emit (events.js:223:5)
    at addChunk (_stream_readable.js:309:12)
    --------------------
    at Protocol._enqueue (C:\Dev\Programmierung\FitnessAppExpo\node_modules\mysql\lib\protocol\Protocol.js:144:48)
    at Protocol.handshake (C:\Dev\Programmierung\FitnessAppExpo\node_modules\mysql\lib\protocol\Protocol.js:51:23)
    at Connection.connect (C:\Dev\Programmierung\FitnessAppExpo\node_modules\mysql\lib\Connection.js:116:18)
    at Object.<anonymous> (C:\Dev\Programmierung\FitnessAppExpo\server\server.js:29:5)
    at Module._compile (internal/modules/cjs/loader.js:955:30)
    at Object.Module._extensions..js (internal/modules/cjs/loader.js:991:10)    
    at Module.load (internal/modules/cjs/loader.js:811:32)
    at Function.Module._load (internal/modules/cjs/loader.js:723:14)
    at Function.Module.runMain (internal/modules/cjs/loader.js:1043:10)
    at internal/main/run_main_module.js:17:11 {
  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
}

我有一个在本地主机上使用 myphpadmin 运行的 Xampp 服务器。我尝试在 myphpadmin 中插入此代码:

ALTER USER 'root'@'localhost' IDENTIFIED WITH mysql_native_password BY '';

但是如果我尝试使用它,它会在 phpmyadmin 中出现错误:

在开始新的 ALTER 操作之前缺少“,”!

第二个声明:

未知的 ALTER 操作(附近)

当我想在 phpmyadmin 中使用或执行这个命令时,我需要做一些特别的事情吗?因为 ALTER 查询的编写方式不允许我执行它..

节点(快递)代码:

var mysql = require("mysql");
var express = require("express");
var session = require("express-session");
var app = express();
var cors = require("cors");

var bodyParser = require("body-parser");
app.use(bodyParser.json({ limit: "50mb" }));
app.use(bodyParser.urlencoded({ limit: "50mb", extended: true }));

app.use(
  session({
    secret: "ssshhhhh",
    saveUninitialized: true, // (default: true)
    resave: true
  })
);

app.use(cors({ origin: ["http://localhost:4200"], credentials: true }));

var con = mysql.createConnection({
  host: "localhost",
  // host: "127.0.0.1:3307",
  user: "root",
  password: "",
  database: "fitness_app"
});

con.connect(err => {
  if (err) throw err;
  console.log("Database connected -> ");
});

var server = app.listen(8090, () => {
  var host = "localhost";
  var port = server.address().port;
  console.log("App listening at http://%s:%s", host, port);
}); 

~褪色

javascript mysql node.js express
2个回答
1
投票

在 MYSQL Workbench 中执行以下查询

 ALTER USER 'root'@'localhost' IDENTIFIED WITH mysql_native_password BY 'password';

其中 root 作为您的用户 localhost 作为您的 URL,密码作为您的密码

然后运行此查询来刷新权限:

flush privileges;

执行此操作后尝试使用节点进行连接。

如果这不起作用,请尝试不使用@'localhost'部分。


0
投票

使用包

mysql2
而不是
mysql
。要安装你可以运行

npm install mysql2

只需将

const mysql = require('mysql');
更改为
const mysql = require('mysql2');
对我有用。

错误原因: MySQL 8 使用新的身份验证协议。 mysql2 支持新协议,但 mysqljs/mysql 不支持

原始答案:https://stackoverflow.com/a/66561311/12731030

© www.soinside.com 2019 - 2024. All rights reserved.