Delphi-PRAXiS

Delphi-PRAXiS (https://www.delphipraxis.net/forum.php)
-   Netzwerke (https://www.delphipraxis.net/14-netzwerke/)
-   -   Delphi WebSite von Server zum Client "pushen" (CGI Script) (https://www.delphipraxis.net/8762-website-von-server-zum-client-pushen-cgi-script.html)

tini 11. Sep 2003 14:56


WebSite von Server zum Client "pushen" (CGI Script
 
Hi @ all!

Ich hab ein Problem: Ich möchte gerne eine Seite zum Client senden obwohl kein Request erfolgt ist. D.h. der Client sendet schon ein Request zur Datenbankabfrage zum Server.
Diese dauert u.Umständen aber sehr lang, und in dieser Zeit soll zum Client ein Seite mit Sanduhr oder ähnlichem gesendet werden, bis DB Abfrage fertig ist.

Kennt sich da jemand aus?

thanx, tini :spin:

Christian Seehase 11. Sep 2003 15:23

Re: WebSite von Server zum Client "pushen" (CGI Sc
 
Moin tini,

ich hab' jetzt zwar schon länger kein CGI Programm mehr erstellt, aber wer hindert Dich daran, statt der Seite mit den angeforderten Daten erst einmal eine "Bitte warten" Seite abzuschicken, und später dann die mit den Daten.

Chewie 11. Sep 2003 16:13

Re: WebSite von Server zum Client "pushen" (CGI Sc
 
Zitat:

Zitat von tini
Ich hab ein Problem: Ich möchte gerne eine Seite zum Client senden obwohl kein Request erfolgt ist. D.h. der Client sendet schon ein Request zur Datenbankabfrage zum Server.


Das versteh ich nicht: Du willst einem HTTP-Clienten etwas schicken, obwohl der gar nichts von dir will? Das wird der Client nie verarbeiten, außerdem, woher weißt du dessen IP?
Ich glaub, ich versteh dein Problem nicht ganz :cry:

theomega 11. Sep 2003 16:15

Re: WebSite von Server zum Client "pushen" (CGI Sc
 
Das geht, ganz sicher, ich habe einen Chat, der macht genau das: der reloaded nicht immer so, wie es die normalen tun, sondern sendet erst an die User einen Befehl zum reloaden, wenn wirklich Daten da sind!

Christian Seehase 11. Sep 2003 16:16

Re: WebSite von Server zum Client "pushen" (CGI Sc
 
Moin Chewie,

Zitat:

Zitat von tini
D.h. der Client sendet schon ein Request zur Datenbankabfrage zum Server.


Chewie 11. Sep 2003 16:43

Re: WebSite von Server zum Client "pushen" (CGI Sc
 
Tut mir leid, jetzt versteh ich gar nix mehr.
Ein Webserver schickt soll einem Client eine Seite senden, obwohl der Client keine Anfrage geschickt hat. Nun wurde aber doch eine Anfrage geschickt :shock:

Na ja, solange du es verstehst, Chris, iss ja alles gut :nerd:

Christian Seehase 11. Sep 2003 17:04

Re: WebSite von Server zum Client "pushen" (CGI Sc
 
Moin Chewie,

ein Client ruft ein CGI Programm aufgerufen, dass Daten aus einer Datenbank abfragt, und diese dann, vermutlich aufbereitet, in Form einer HTML Datei an den Client zurückschickt.
Da diese Datenbankabfrage wohl etwas dauern kann möchte tini nun wissen, ob man zwischendurch auch eine andere HTML Datei zurückschicken kann.

Soweit das, was ich aus tinis Frage heraus verstanden habe.

Na ja, meine Antwort dazu steht ja schon da ;-)

tini 12. Sep 2003 08:07

Re: WebSite von Server zum Client "pushen" (CGI Sc
 
Hi!

Christian schreibt:

Zitat:

wer hindert Dich daran, statt der Seite mit den angeforderten Daten erst einmal eine "Bitte warten" Seite abzuschicken, und später dann die mit den Daten.
Genau das habe ich ja vor, bloß erfolgt nach der "bitte warten" seite kein weiters Request des Clients und nun weiß ich nicht, wie man die Seite dann trotzdem sendet. (via IP Adresse des Clients, Cookie, ...?).
oder über <head><meta http-equiv="expires"...> im html Teil?

@Chewie:

Die IP Adresse des Clients bekomm ich ohne weiteres durch das CGI Script.
Zb:
Delphi-Quellcode:
IP:= Request.RemoteAddr;
Und wie Christian schont schrieb, möchte ich, da die Datenbankanfrage länger dauert, eine "Bitte Warten" Seite "einschieben", bis das Ergebnis da ist-sonst denkt der User, das Programm hat sich aufgehängt oder so.

mfg
tini :spin:

Wormid 12. Sep 2003 09:17

Re: WebSite von Server zum Client "pushen" (CGI Sc
 
Soweit mir bekannt ist, gibt es keine möglichkeit, das übers "pushen" zu lösen...

Viele Seiten die scheinbar so was machen, realisieren das über einen Trick:
Es wird eine halbe Seite zum Client gestreamt, mit einem Layer (in dhtml) z.B. der Anzeigt "Bitte warten - Daten werden sortiert". Der Server (bzw. das CGI-Script darf dabei aber die Verbindung zum Client nicht beenden.
Wenn die langwierige Verarbeitung auf dem Server abgeschlossen ist, gibt das CGI-Script zunächst etwas JavaScript aus, das den "Bitte warten..."-Layer abschaltet und danach die restliche Seite ausgibt.

Im Moment habe ich dazu kein konkretes Beispiel an der Hand, aber mit ein bisschen gesuche... *g*


Gruß

Wormid

Wormid 12. Sep 2003 09:31

Re: WebSite von Server zum Client "pushen" (CGI Sc
 
Ein kleines Beispiel zu meinem Denkansatz aus einem Usercomment in der PHP-Dokumentation...

Schritt 1, vor der langwierigen Datenbankoperation:
Zitat:

the part that you want to show during the 'processing' has to be embedded in a SPAN tag like so:

echo "<span id=\"processing\">analysing data...</span>";
flush();
Schritt 2, nach der dicken Datenbankoperation...
Zitat:

then the long calculations will follow, after a few seconds you then simply send:

echo "<script>processing.style.display='none'</script>";

taadaa, and the part within the SPAN tags will disappear.
Ich denke, das sollte so auch ohne weiteres auf Delphi übertragbar sein.

Gruß

Wormid

tini 12. Sep 2003 09:42

Re: WebSite von Server zum Client "pushen" (CGI Sc
 
Also auf die Lösung mit den Layern bin ich auch schon gestoßen.
Ist nur die Frage, wie ich das mit der html seite mache (ausleitende tags...</body></html> etc.).

Bevor die Seite abgeschlossen wird, müsste ich ja dann erstmal die Abfrage starten, und danach dann das Ergebnis und abschließende Tags der html seite zum client senden!
Ist das funtkionsfähig?

mfg tini

Wormid 12. Sep 2003 10:02

Re: WebSite von Server zum Client "pushen" (CGI Sc
 
Die abschliessenden Tags dürfen natürlich noch nicht übertragen werden.

Es müsste in etwa so aussehen:

Code:
<html>
<head>
  ...
</head>

<body>
...
<span id="processing">Bin am Verarbeiten am tun dranne... ;-)</span>
An dieser Stelle muss das Script den Ausgabebuffer an den Client senden und dann die zeitintensive Aktion starten. Sobald die durch ist, müsste es mit der Ausgabe so ungefähr weitergehen...

Code:
<script>processing.style.display = "none"</script>
...
Lorem ipsum... etc...
</body>
</html>

FriFra 12. Sep 2003 10:50

Re: WebSite von Server zum Client "pushen" (CGI Sc
 
Solange aber keine ausleitenden Tags vorhanden sind kann man sich aber nicht darauf verlassen, dass die Seite überhaupt schon angezeigt wird!
Warum machst du nicht einfach eine Zwischenseite:

Ausgangsseite
|
Zwischenseite (Bitte warten) -> Request an DB-Funktion
|
Ergebnisseite


Jetzt könnte es passieren, dass die Seite von der DB-Applikation als "noch leere" Seite die bitte warten Seite wegbügelt, das kannst Du aber verhindern, indem Du die Seite erst anzeigst, wenn sie vollständig geladen ist.
das geht z.B. mit folgender Zeile im Head der Ergebnisseite:
Code:
<META HTTP-EQUIV="Page-Enter" CONTENT="revealTrans(Duration=0.6,Transition=12)">
P.S.: Push kannst Du Gott sei Dank vergessen, sonst könnte Dir z.B. jeder jede beliebige Datei ungefragt auf deinen Rechner senden ;)

Chewie 12. Sep 2003 11:13

Re: WebSite von Server zum Client "pushen" (CGI Sc
 
Wie wärs mit einem Meta-Refresh?
Du schreibst hin "Bitte Warten", und in den Meta-Tag fügst du einen Meta-Refresh ein, der sofort mit der zeitintensiven Aktion beginnt. Erst wenn sie fertig ist, wird die nächste Seite geladen. Dieses Verfahren wird z.B. von einigen Webmailclienten benutzt.

Edit: OK, ich sehe, das ist FriFras Vorschlag, aber ich hab noch dazu geschrieben, wie der HTML-Tag dazu heißt ;-)

FriFra 12. Sep 2003 11:15

Re: WebSite von Server zum Client "pushen" (CGI Sc
 
@Chewie: Das ist ja mein Beispiel "auf Links gedreht" ;) ...

tini 16. Sep 2003 15:36

Re: WebSite von Server zum Client "pushen" (CGI Sc
 
Hi!!!
Danke für Eure Hilfe!

Also das mit
Delphi-Quellcode:
<META HTTP-EQUIV="Page-Enter" CONTENT="revealTrans(Duration=0.6,Transition=12)">
habe ich probiert.
Aber es funktioniert nicht. :( Ich glaube es liegt daran, dass der Server die .exe erst komplett ausführt, und danach die Verbindung zum Client wieder aufbaut und das Ergebnis bzw. die Ergebnisseite übermittelt (es werden nämlich auch "Bitte warten..." Seite und "Ergebnisseite" erst nach der DB-Abfrage auf EINER Seite dem Client zugestellt, trotz jeweiliger ausleitender tags der einzelnene Seiten).

Nun fragt sich, wie man die Verbindung zum Client schon vorher wieder herstellen kann... (nur die IP Adresse wird da nicht langen...) und die "Bitte warten" Seite schon eher versendet(also vor db abfrage und bevor .exe Datei beendet.

mfg tini :spin:

Chewie 16. Sep 2003 15:51

Re: WebSite von Server zum Client "pushen" (CGI Sc
 
Nochmal, ich würde folgendermaßen vorgehen:

Situation: Der Client will was von dir (Webserver), was etwas länger dauern wird.

1. Du schickst ihm eine Seite, auf der "Bitte warten" (oder so was ähnliches) steht
2. Diese Seite enthält einen Meta-Refresh (mit Intervall 0 Sekunden), der das Script lädt, das die Aktion durchführen wird
3. Du sendest erst wieder Daten an den Client, wenn deine Berechnung ganz abgeschlossen ist
4. Der Client hat jetzt die Bitte-Warten-Seite auf dem Bildschirm, bis deine Berechnung fertig ist und er die neue Seite fertig laden kann.

tini 18. Sep 2003 09:01

Re: WebSite von Server zum Client "pushen" (CGI Sc
 
Hallo!

Merci an Euch!! Jetzt klappt's wunderbar!!!

mfg

tini :spin:


Alle Zeitangaben in WEZ +1. Es ist jetzt 02:12 Uhr.

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