Sichere Verbindung zu einem MySQL-Server über SSH mit PHP
Die Verbindung zu einem Remote-MySQL-Server über SSH bietet zusätzliche Sicherheit durch die Verschlüsselung der Verbindung. In PHP ermöglicht die Funktion mysqli_connect() die Verbindung zu SSH-getunnelten MySQL-Servern. Beim Versuch, eine Verbindung mit ssh2_tunnel() herzustellen, stoßen Entwickler jedoch häufig auf den Fehler „mysqli_connect() erwartet, dass Parameter 6 ein String ist, Ressource angegeben.“
SSH-Tunnelkonfiguration
Der empfohlene Ansatz zur Lösung dieses Problems besteht darin, einen SSH-Tunnel einzurichten. Befolgen Sie diese Schritte, um mit Befehlszeilentools einen SSH-Tunnel zu erstellen:
ssh -fNg -L 3307:10.3.1.55:3306 username@ssh-jumpbox.com
AllowTcpForwarding yes
sudo systemctl restart sshd
PHP-Verbindung
Sobald der SSH-Tunnel eingerichtet ist, können Sie Stellen Sie mit PHP eine Verbindung zum MySQL-Server her:
$mysqli = new mysqli('127.0.0.1', 'DB_USERNAME', 'DB_PASSWORD', 'dbname', 3307); if ($mysqli->connect_error) { die('Connect Error (' . $mysqli->connect_errno . ') ' . $mysqli->connect_error); }
Dieser Code stellt eine Verbindung zur MySQL-Datenbank her, die unter 127.0.0.1:3307 gehostet wird, und zwar unter Verwendung des angegebenen Datenbank-Benutzernamens, Passworts, Datenbanknamens und der für die konfigurierten Portnummer SSH-Tunnel.
Das obige ist der detaillierte Inhalt vonWie kann ich über einen SSH-Tunnel in PHP eine sichere Verbindung zu einem Remote-MySQL-Server herstellen?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!