Wie behebe ich den Fehler „mysqli_connect() erwartet Parameter 6 als Zeichenfolge, Ressource angegeben' beim Herstellen einer Verbindung zu MySQL über SSH in PHP?

Patricia Arquette
Freigeben: 2024-10-21 22:32:02
Original
363 Leute haben es durchsucht

How to Resolve

Herstellen einer Verbindung zu einem MySQL-Server über SSH in PHP

Problem:

Beim Herstellen einer Verbindung zu Ihrer Datenbank über SSH ist ein Fehler aufgetreten ssh2-Bibliothek. Konkret lautet der Fehler „mysqli_connect() erwartet, dass Parameter 6 ein String ist, Ressource angegeben.“

Erklärung des Problems:

Die obige Fehlermeldung deutet darauf hin, dass Sie einen falschen Typ an übergeben haben sechster Parameter der mysqli_connect-Funktion.

Lösung:

Um das Problem zu beheben, übergeben Sie als sechsten Parameter eine Zeichenfolge anstelle einer Ressource. In Ihrem Fall wird dieser Parameter voraussichtlich der Pfad zum SSH-Tunnel-Socket sein.

SSH-Tunnel-Setup:

Um über SSH eine Verbindung zu einem MySQL-Server herzustellen, müssen Sie den Tunnel einrichten Erstellen Sie einen SSH-Tunnel mit den folgenden Schritten:

1. SSH-Tunnel-Befehl:

ssh -fNg -L 3307:10.3.1.55:3306 [email protected] 
Nach dem Login kopieren
  • '-f': Im Hintergrund ausführen
  • '-N' : Führen Sie keinen Remote-Befehl aus
  • '-L': Lokale Portweiterleitung aktivieren
  • '3307': Lokaler Port auf Ihrem Computer
  • '10.3.1.55': Remote-MySQL-Serveradresse
  • '3306': Remote-MySQL-Server-Port
  • '[email protected]': SSH-Proxy-Host und Benutzername

2. MySQL-Client-Verbindung:

Sobald der Tunnel eingerichtet ist, können Sie über Ihren lokalen MySQL-Client eine Verbindung zu Ihrem MySQL-Server herstellen:

mysql -h 127.0.0.1 -P 3307 -u dbuser -p passphrase
Nach dem Login kopieren
  • '- h': Lokale MySQL-Serveradresse
  • '-P': Lokale Portnummer
  • '-u': MySQL-Benutzername
  • '-p': MySQL-Passwort

3. PHP-Verbindung:

Stellen Sie abschließend eine Verbindung zu Ihrem MySQL-Server in Ihrer PHP-Anwendung her:

<code class="php"><?php
$smysql = mysql_connect("127.0.0.1:3307", "dbuser", "passphrase");
mysql_select_db("db", $smysql); 
?></code>
Nach dem Login kopieren

Sicherheitshinweis:

Für erweiterte Um Ihre Sicherheit zu gewährleisten, verwenden Sie einen Bastion-Host (Jumpbox) als SSH-Proxy, anstatt eine direkte Verbindung zu Ihrem MySQL-Server herzustellen.

Das obige ist der detaillierte Inhalt vonWie behebe ich den Fehler „mysqli_connect() erwartet Parameter 6 als Zeichenfolge, Ressource angegeben' beim Herstellen einer Verbindung zu MySQL über SSH in PHP?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Quelle:php
Erklärung dieser Website
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
Neueste Artikel des Autors
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage
Über uns Haftungsausschluss Sitemap
Chinesische PHP-Website:Online-PHP-Schulung für das Gemeinwohl,Helfen Sie PHP-Lernenden, sich schnell weiterzuentwickeln!