Delphi-PRAXiS
Seite 1 von 2  1 2      

Delphi-PRAXiS (https://www.delphipraxis.net/forum.php)
-   Netzwerke (https://www.delphipraxis.net/14-netzwerke/)
-   -   Delphi Mit Indy (TIdFTP) Script hochladen klappt nicht (https://www.delphipraxis.net/161051-mit-indy-tidftp-script-hochladen-klappt-nicht.html)

BlueStarHH 14. Jun 2011 14:18

Mit Indy (TIdFTP) Script hochladen klappt nicht
 
Hallo,

ich möchte mit Indy (TIdFTP) ein Perl-CGI-Script auf meinem Webserver hochladen. Das klappt auch. Die Datei ist da, nur wenn ich sie über den Browser aufrufe erscheint die Meldung "Premature end of script headers". Wenn ich das Perl-CGI-Script mit einem FTP-Programm hochlade, wird sie einwandfrei ausgefürt. Was macht das FTP-Programm anders als Indy?

Delphi-Quellcode:
IdFTP1.Connect;
IdFTP1.TransferType := ftASCII;
IdFTP1.Put(FileName, '\cgi-bin\meinscript.cgi');
IdFTP1.Disconnect;

DeddyH 14. Jun 2011 14:26

AW: Mit Indy (TIdFTP) Script hochladen klappt nicht
 
Und wenn Du die Datei einmal binär überträgst?

BlueStarHH 14. Jun 2011 15:38

AW: Mit Indy (TIdFTP) Script hochladen klappt nicht
 
Zitat:

Zitat von DeddyH (Beitrag 1106320)
Und wenn Du die Datei einmal binär überträgst?

Komisch, es geht nur wenn ich es wie folgt mache:

Delphi-Quellcode:
IdFTP1.Connect;
IdFTP1.TransferType := ftASCII;
IdFTP1.TransferType := ftBinary;
IdFTP1.Put(FileName, '\cgi-bin\meinscript.cgi');
IdFTP1.Disconnect;
Bei der ersten Zuweisung von TransferType wird Code im Setter noch nicht ausgeführt. Erst in der zweiten Zuweisung. Denn wenn man IdFTP1.TransferType := ftASCII; weglässt, kann das Script nicht ausgeführt werden.

Was noch komischer ist: Überall steht, dass man Perl-CGI-Scripte als ASCII übertragen soll, da sonst die Zeilenübrüche defekt sind und das Script nicht ausgeführt werden kann. Hier muss ich es aber als binär übertragen, damit es läuft. Hat jemand Vermutungen was hier los ist?

blackfin 14. Jun 2011 15:48

AW: Mit Indy (TIdFTP) Script hochladen klappt nicht
 
Deine Script-CGI-Datei ist aber nicht zufälligerweise Unicode? :-)

alfold 14. Jun 2011 16:13

AW: Mit Indy (TIdFTP) Script hochladen klappt nicht
 
Zitat:

Zitat von BlueStarHH (Beitrag 1106316)
....
Wenn ich das Perl-CGI-Script mit einem FTP-Programm hochlade, wird sie einwandfrei ausgefürt. Was macht das FTP-Programm anders als Indy?

Die meisten FTP Progs (Putti, Winscp)schieben die Dateien Binär hoch!
Es sei, man stellt es anders ein:wink:

Zitat:

Zitat von blackfin (Beitrag 1106339)
Deine Script-CGI-Datei ist aber nicht zufälligerweise Unicode? :-)

Wie sollte es. Wenn er es mit anderen Progs hoch schiebt und es funct:wink:

Gruss alfold

blackfin 14. Jun 2011 16:17

AW: Mit Indy (TIdFTP) Script hochladen klappt nicht
 
Zitat:

Wie sollte es. Wenn er es mit anderen Progs hoch schiebt und es funct
Naja, der Server kann ja vielleicht, bzw. ziemlich sicher Unicode-Perl-Scripte ausführen.
Allerdings, wenn man eine Unicode-codierte Datei mit Ascii-Encoding hochschiebt, kann das durchaus die Datei zerstören.
Andere Clients erkennen u.U. trotz eingestelltem ASCII-Transfer, dass eine Datei Unicode ist und schieben sie dann binär hoch (SmartFTP macht das z.B.)
Und das ist auch richtig, Unicode-Dateien sollte man nicht mit ASCII-Transfer hochladen, das gibt Verwurschtelungen.

BlueStarHH 14. Jun 2011 16:21

AW: Mit Indy (TIdFTP) Script hochladen klappt nicht
 
Zitat:

Zitat von blackfin (Beitrag 1106339)
Deine Script-CGI-Datei ist aber nicht zufälligerweise Unicode? :-)

Nein, kein Unicode. Lädt Indy die Datei intern evtl. als Unicode und überträgt die dann? Mit einer alten nicht Unicode Version von Indy gab es nämlich keine Probleme...

blackfin 14. Jun 2011 16:48

AW: Mit Indy (TIdFTP) Script hochladen klappt nicht
 
Kann gut sein...wenn man sich den Quellcode von der idFTP ansieht, sind da ein paar merkwürdige Sachen mit dem Encoding...
Schickst du an den Server vorher ein "FEAT"-Command?
Da scheint Indy dann das Default Encoding für den String-I/O-Handler auf UTF8 zu stellen:
Delphi-Quellcode:
IOHandler.DefStringEncoding := enUTF8;
hm...
Versuche doch mal, die Datei nicht über die Angabe eines Dateinamens im put-Befehl hochzuschieben, sondern mach die Datei vorher über einen TFileStream auf und übergib den an put.

BlueStarHH 17. Jun 2011 10:37

AW: Mit Indy (TIdFTP) Script hochladen klappt nicht
 
Ich hab den Fehler in der IdFTP.pas gefunden:

Delphi-Quellcode:
procedure TIdFTP.SetTransferType(AValue: TIdFTPTransferType);
begin
  if AValue <> FTransferType then begin
    FTransferType := AValue; //von unten nach hier verschoeben
    if not Assigned(FDataChannel) then begin
      if Connected then begin
        SendTransferType;
      end;
      //FTransferType := AValue; //muss nach oben
    end;
  end;
end;
Wenn die markierte Zeile nicht verschoben wird, setzt SendTransferType immer den vorherigen FTransferType und nicht den aktuellen.

CCRDude 17. Jun 2011 10:45

AW: Mit Indy (TIdFTP) Script hochladen klappt nicht
 
Verwendest Du eine ältere Version von Indy?

Bei mir (mit DXE mitgeliefertes Indy 10) steht nämlich schon:
Code:
procedure TIdFTP.SetTransferType(AValue: TIdFTPTransferType);
begin
  if AValue <> FTransferType then begin
    if not Assigned(FDataChannel) then begin
      if Connected then begin
        SendTransferType(AValue);
      end;
      FTransferType := AValue;
    end;
  end;
end;


Alle Zeitangaben in WEZ +1. Es ist jetzt 23:24 Uhr.
Seite 1 von 2  1 2      

Powered by vBulletin® Copyright ©2000 - 2024, Jelsoft Enterprises Ltd.
LinkBacks Enabled by vBSEO © 2011, Crawlability, Inc.
Delphi-PRAXiS (c) 2002 - 2023 by Daniel R. Wolf, 2024 by Thomas Breitkreuz