Einzelnen Beitrag anzeigen

Delphi.Narium

Registriert seit: 27. Nov 2017
2.508 Beiträge
 
Delphi 7 Professional
 
#22

AW: Eine isapi dll für Apache 2.4 soll CMD ausführen

  Alt 22. Mär 2021, 13:25
Fragen wir mal so:

Was bezweckst Du denn mit dem Aufruf einer Batchdatei über eine ISAPI.dll?

Soll da irgendwas initialisiert werden?
Was auf der Kommandozeile erstellt, um es dann an den Client auszuliefern?

oder oder oder?

Man kann auch statt 'ner ISAPI.dll ein CGI-Programm nehmen, wobei ein CGI-Programm durchaus auch eine Batchdatei sein kann (kommt wohl etwas auf den Webserver an).

Aus 'ner ISAPI.dll kann man recht einfach ein CGI-Programm machen:
Delphi-Quellcode:
{-- $DEFINE DLL}
{$IFDEF DLL}
library Bibliothek;
[$ELSE}
program CGI;
{$APPTYPE CONSOLE}
{$ENDIF}
uses
  WebBroker,
{$IFDEF DLL}
  HTTPApp,
  ISAPIApp,
[$ELSE}
  CGIApp,
{$ENDIF}
  WebModuleUnit1 in 'WebModuleUnit1.pas{WebModule1: TWebModule};

{$R *.RES}

{$IFDEF DLL}
exports
  GetExtensionVersion,
  HttpExtensionProc,
  TerminateExtension;
{$ENDIF}

begin
  Application.Initialize;
  Application.CreateForm(Twm, wm);
  Application.Run;
end.
Ist jetzt nur hingedaddelt, aber grob sollte es so funktionieren. Damit kann man dann bis zur vollen Funktionsfähigkeit als CGI entwickeln und wenn das dann zur Zufriedenheit funktioniert, macht man aus dem {-- $DEFINE DLL} ein {$DEFINE DLL} und erstellt sich damit, statt der CGI.exe die ISAPI.dll.

Achso: Meines Wissens bekommt man weder über ein CGI-Programm noch eine ISAPI.dll ein automatisches Laden einer Batchdatei beim Start des Apache geregelt. Beide werden erst beim Aufruf über eine Url aus 'nem Browser, 'nem Delphiprogramm mit Indys idHTTP.get('http://localhost:17082/cmd_starter.dll'); ... gestartet / geladen.
Damit ist kein Automatismus beim Start des Webservers verbunden. ISAPI.dlls werden (meines Wissens) erst auf Anforderung (beim ersten Aufruf per Url) geladen und nicht automatisch beim Start des Webservers.

Also: Wie von Dir bereits beobachtet:

Webserverneustart <> ISAPI.dll laden.

ISAPI.dll laden = Aufruf über die Url zur ISAPI.dll.

Im Gegensatz zu CGI-Programmen, die bei jedem Aufruf neu gestartet werden, ihren Job erledigen und sich dann beenden, wird eine ISAPI.dll beim erstmaligen Aufruf via Url geladen und bleibt dann bis zum Herunterfahren des Webservers geladen.

Aber: Eine ISAPI.dll wird nicht geladen, solange sie nicht über ihre Url aufgerufen wurde.
ISAPI.dll werden nicht "auf Vorrat" geladen, quasi: Sie ist da, also lade ich sie, egal ob sie irgendwann mal benötigt wird oder nicht, sondern nur, wenn zumindest ein Aufruf per Url erfolgte.

Alternative:

Webserver über 'ne Batch starten und hinter den Start des Webservers noch das anhängen, was nach dem Start des Webservers erledigt werden soll.
  Mit Zitat antworten Zitat