FTP: 425 Can't open data connection for transfer (Filezilla)

nietaL

NGBler
Registriert
8 Sep. 2013
Beiträge
231
Ort
Exilgullianer
Hey Leute!

Ich habe zwei Server. Server A ist ein Webserver und soll mittels PHP über FTP eine Datei auf Server B übertragen, auf dem der Filezilla-Server installiert ist.

Ich kann problemlos über den angelegten Benutzer+Passwort über meinen CuteFTP-Client connecten und hochladen (von meinem Heim-PC aus!).

$server = '';
$ftp_user_name = '';
$ftp_user_pass = '';
$dest = "";
$source = "";
$src = ini_get("upload_tmp_dir");

$connection = ftp_connect($server);
$login = ftp_login($connection, $ftp_user_name, $ftp_user_pass);
if (!$connection || !$login) { die('Connection attempt failed!'); }
$upload = ftp_put($connection, $dest, $source, FTP_BINARY);
if (!$upload) { echo 'FTP upload failed!'; }
ftp_close($connection);



Ein simples FTP/PHP-Skript soll nun dasselbe tun, mit den selben Zugangsdaten. Allerdings vom Webserver aus. Die Verbindung wird hergestellt, aber dann kommt es zum Timeout.
Die Webseite gibt einen 500er zurück und das Protokoll vom Filezilla-Server sagt:

(048865)17.02.2017 17:49:11 - (not logged in) (XX.XXX.XX.XXX)> Connected on port 21, sending welcome message...
(048865)17.02.2017 17:49:11 - (not logged in) (XX.XXX.XX.XXX)> USER OurAltis
(048865)17.02.2017 17:49:11 - (not logged in) (XX.XXX.XX.XXX)> 331 Password required for ouraltis
(048865)17.02.2017 17:49:11 - (not logged in) (XX.XXX.XX.XXX)> PASS ********
(048865)17.02.2017 17:49:11 - benutzername (XX.XXX.XX.XXX)> 230 Logged on
(048865)17.02.2017 17:49:11 - benutzername (XX.XXX.XX.XXX)> TYPE A
(048865)17.02.2017 17:49:11 - benutzername (XX.XXX.XX.XXX)> 200 Type set to A
(048865)17.02.2017 17:49:11 - benutzername (XX.XXX.XX.XXX)> PORT YY,YYY,YY,YYY,YYY,YYY
(048865)17.02.2017 17:49:11 - benutzername (XX.XXX.XX.XXX)> 200 Port command successful
(048865)17.02.2017 17:49:11 - benutzername (XX.XXX.XX.XXX)> STOR Pfad\zum\Ziel.txt
(048865)17.02.2017 17:49:11 - benutzername (XX.XXX.XX.XXX)> 150 Opening data channel for file upload to server of "/Pfad/zum/Ziel.txt"
(048865)17.02.2017 17:49:21 - benutzername (XX.XXX.XX.XXX)> 425 Can't open data connection for transfer of "/Pfad/zum/Ziel.txt"
(048865)17.02.2017 17:50:07 - benutzername (XX.XXX.XX.XXX)> disconnected.

Zu Testzwecken habe ich die Firewall auf dem Server B (mit Filezilla-Server) deaktiviert. Selbes Problem.

Ideen?
 
Zuletzt bearbeitet:
Hast du dem Verzeichnis korrekte Schreibrechte gegeben? Zum Beispiel chmod 777? Geht auch über Filezilla, Ordnerberechtigungen setzen.

Wobei, ich hab jetzt mal kurz nach dem Fehler 425 geschaut, scheint wohl an "passiven Übertragungsports" zu liegen, vielleicht sind die auf dem übertragenden Server nicht offen?
Aber das mit den Schreibrechten würde ich trotzdem kurz testen.
 
Zuletzt bearbeitet:
  • Thread Starter Thread Starter
  • #3
Danke für deine ersten Hinweise. Es handelt sich um eine Win-Server, also komm ich mit chmod777 nicht weit. Ich habe manuell der ausführenden Datei Vollzugriff erteilt (Rechtsklick, Sicherheit, Berechtigungen).
Problem bleibt bestehen.

Im Übrigen gibt der Browser mittlerweile folgendes zurück, da ich das Skript aus Debugging-Gründen einmal auf das reine FTP-Skript reduziert habe:
Warning: ftp_put() [function.ftp-put]: Opening data channel for file upload to server of "/transparentpixel.gif" in C:\Inetpub\vhosts\XXXXX\httpdocs\test.php on line 12
Fatal error: Maximum execution time of 60 seconds exceeded in C:\Inetpub\vhosts\XXXXX\test.php on line 12

Die Passiv-Ports habe ich wie folgt eingestellt:

scree.jpg



*edit* Vielleicht lernt ein anderer daraus:

Der Tip mit dem Passiv-Modus verhalf mir zur Idee zu prüfen, ob denn überhaupt der Passiv-Modus von meinem Skript verwendet wird. Denn ein fix installierter FTP-Client mit GUI, der den Passiv-Modus verwendet funktionierte auf jenem sendeden Server. Also fügte ich meinem Skript noch folgendes hinzu:
[src=php]ftp_pasv($connection, true);[/src]

Klappte sofort! Danke noch 'mal.
 
Zuletzt bearbeitet:
FTP ist eine ganz schlechte Idee (unverschlüsselt), kannst du denn kein anderes Protokoll nutzen? Da bietet sich bspw. an.

Auch der FileZilla Server ist nicht gerade die beste Idee, um Dateien zu übertragen.
 
Jop Benutzername und Passwort werden im klartext übertragen und können z.B. im Quell und Zielnetzwerk simpel abgefangen werden.
Ganz davon abgesehen vom Inhalt.
Zusätzlich musst du an die Laufzeit deines Scriptes denken - je nach Dateigröße die du jetzt aber auch irgendwann später übertragen möchtest.
 
Zurück
Oben