Mengapakah Saya Mendapat Ralat 'ER_NOT_SUPPORTED_AUTH_MODE' Menyambung ke MySQL daripada Node.js?

Mary-Kate Olsen
Lepaskan: 2024-11-10 02:14:02
asal
262 orang telah melayarinya

Why am I Getting

Menyelesaikan masalah "ER_NOT_SUPPORTED_AUTH_MODE" Ralat dalam Sambungan MySQL-Node.js

"ER_NOT_SUPPORTED_AUTH_MODE" Ralat dalam MySQL-Node.js Connection

"ER_NOT_SUPPORTED_MODE" menunjukkan ralat No.js. tidak dapat mewujudkan sambungan dengan pelayan MySQL kerana protokol pengesahan yang tidak disokong. Isu ini timbul apabila pelayan MySQL memerlukan kaedah pengesahan khusus yang pelanggan tidak menyokong.

Dalam kes anda, anda telah meningkatkan daripada MariaDB kepada MySQL. Walau bagaimanapun, coretan sambungan JavaScript yang anda gunakan mungkin masih menggunakan protokol pengesahan MariaDB, yang tidak disokong oleh MySQL 8.0 dan ke atas.

Penyelesaian:

Untuk menyelesaikan isu ini, anda perlu menaik taraf klien Node.js anda untuk menyokong protokol pengesahan asli MySQL. Protokol ini serasi dengan kedua-dua pelayan MariaDB dan MySQL.

ALTER USER 'root'@'localhost' IDENTIFIED WITH mysql_native_password BY 'password';
Salin selepas log masuk
Untuk MySQL versi 8.0 dan ke atas, gunakan arahan berikut untuk mengemas kini kaedah pengesahan pengguna root:

Ganti "root" dengan nama pengguna dan "kata laluan" dengan kata laluan yang dikehendaki.

FLUSH PRIVILEGES;
Salin selepas log masuk
Setelah kaedah pengesahan telah dikemas kini, laksanakan arahan berikut untuk mengaktifkan perubahan:

var mysql = require('mysql');

var connection = mysql.createConnection({
    host: 'localhost',
    user: 'root',
    password: 'password',
    database: 'foobarDb',
    authPlugin: 'mysql_native_password' // specify the MySQL native authentication protocol
});
Salin selepas log masuk
Sekarang, ubah suai coretan sambungan JavaScript anda untuk menggunakan protokol asli MySQL:

Ini sepatutnya menyelesaikan ralat "ER_NOT_SUPPORTED_AUTH_MODE" dan membolehkan anda menyambung ke pangkalan data MySQL dari pelayan Node.js anda.

Atas ialah kandungan terperinci Mengapakah Saya Mendapat Ralat 'ER_NOT_SUPPORTED_AUTH_MODE' Menyambung ke MySQL daripada Node.js?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

sumber:php.cn
Kenyataan Laman Web ini
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn
Artikel terbaru oleh pengarang
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan