Heim >Datenbank >MySQL-Tutorial >Warum kann sich meine Node.js-App nicht bei MySQL 8.0 authentifizieren?

Warum kann sich meine Node.js-App nicht bei MySQL 8.0 authentifizieren?

Susan Sarandon
Susan SarandonOriginal
2024-11-30 14:29:14260Durchsuche

Why is My Node.js App Failing to Authenticate with MySQL 8.0?

Node.js-Authentifizierungsprobleme mit MySQL 8.0

Bestimmt beim Versuch, eine Verbindung zu einer MySQL-Datenbank mit dem Root-Konto über Node.js herzustellen Es können Probleme auftreten. Dies ist besonders relevant für MySQL 8.0, wo das Standard-Authentifizierungs-Plugin von mysql_native_password in caching_sha2_password geändert wurde.

Fehlermeldung und Ursache

Beim Versuch, mit einer Node.js-Anwendung eine Verbindung zu MySQL 8.0 herzustellen, Der folgende Fehler kann auftreten:

ER_NOT_SUPPORTED_AUTH_MODE: Client does not support authentication protocol requested by server; consider upgrading MySQL client

Dieser Fehler weist darauf hin, dass die Der MySQL-Treiber von Node.js kann das neue Authentifizierungs-Plugin, das in MySQL 8.0 eingeführt wurde, nicht verwenden.

Problemumgehung:

Um das Problem zu beheben und über das Root-Konto eine Verbindung zu MySQL 8.0 herzustellen, kann das Plugin mysql_native_password dies tun anstelle des standardmäßigen caching_sha2_password verwendet werden. Dies kann durch eine der folgenden Methoden erreicht werden:

  1. Bestehendes Root-Konto ändern:
ALTER USER 'root'@'localhost' IDENTIFIED WITH mysql_native_password BY 'MyNewPass';
  1. Neuen Benutzer mit dem gewünschten Plugin erstellen:
CREATE USER 'foo'@'localhost' IDENTIFIED WITH mysql_native_password BY 'bar';

Alternative Lösung:

Alternativ das offizielle MySQL Der auf dem X-Protokoll basierende Node.js-Connector kann genutzt werden. Dieser Connector unterstützt den neuen Authentifizierungsmodus in MySQL 8.0.

Das obige ist der detaillierte Inhalt vonWarum kann sich meine Node.js-App nicht bei MySQL 8.0 authentifizieren?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn