4D v16.3

WEB SEND RAW DATA

Home

 
4D v16.3
WEB SEND RAW DATA

WEB SEND RAW DATA 


 

WEB SEND RAW DATA ( Daten {; *} ) 
Parameter Typ   Beschreibung
Daten  BLOB in Zu sendende HTTP Daten
Operator in Stückweise senden

Der Befehl WEB SEND RAW DATA legt fest, dass der 4D Web Server HTTP Rohdaten sendet, die gestückelt werden können.
Daten enthält die beiden Standardteile einer HTTP Antwort, das sind Header und Body. Der Server sendet die Daten ohne vorherige Formatierung.
4D überprüft jedoch Header und Body in der Antwort auf ihre Gültigkeit:

  • Ist der Header unvollständig oder passt er nicht zu den Angaben des HTTP Protokolls, führt 4D die entsprechenden Änderungen aus.
  • Ist die HTTP Anfrage unvollständig, fügt 4D die fehlende Information hinzu. Wollen Sie z.B. die Anfrage umleiten (Redirect), müssen Sie schreiben:
   HTTP/1.1 302
   Location: http://...

Übergeben Sie nur:

   Location: http://...

vervollständigt 4D die Anfrage durch Hinzufügen von HTTP/1.1 302.

Mit dem optionalen Parameter * geben Sie an, dass die Antwort “stückweise” gesendet wird. Das Stückeln der Antwort ist hilfreich, wenn der Server eine Antwort sendet, ohne ihre Gesamtlänge zu kennen, z.B. wenn die Antwort nicht generiert wurde. Alle Browser, die mit HTTP/1.1- kompatibel sind, akzeptieren gestückelte Antworten (chunked responses).
Mit dem optionalen Parameter * bindet der Web Server automatisch das Feld transfer-encoding: chunked in den Header der Antwort ein, sofern erforderlich. Sie können den Header der Antwort natürlich auch manuell verwalten. Der Rest der Antwort berücksichtigt beim Formatieren ebenfalls die Option gestückelt. Gestückelte Antworten enthalten einen einzigen Header und eine undefinierte Anzahl Body “Stücke”.

Alle Anweisungen WEB SEND RAW DATA, die auf die Ausführung von WEB SEND RAW DATA (Daten;*) in derselben Methode folgen, gelten als Teil der Antwort, unabhängig, ob mit oder ohne den Parameter *. Der Server beendet die stückweise Übersendung, wenn die Ausführung der Methode abgeschlossen ist.

Hinweis: Unterstützt der Web Client nicht HTTP/1.1, konvertiert 4D die Antwort automatisch in ein mit HTTP/1.0 kompatibles Format (die Daten werden nicht gestückelt gesendet). In diesem Fall entspricht das Ergebnis evtl. nicht Ihren Wünschen. Sie sollten deshalb prüfen, ob der Web Browser HTTP/1.1 unterstützt und eine entsprechende Antwort sendet.

Dafür können Sie folgenden Code verwenden:

 C_BOOLEAN($0)
 ARRAY TEXT(arFields;0)
 ARRAY TEXT(arValues;0)
 WEB GET HTTP HEADER(arFields;arValues)
 $0:=False
 If(Size of array(arValues)>=3)
    If(Position("HTTP/1.1";arValues{3})>0)
       $0:=True ` Browser unterstützt HTTP/1.1; $0 gibt wahr zurück
    End if
 End if

In Kombination mit dem Befehl WEB GET HTTP BODY, sowie anderen Befehlen im Kapitel “Web Server” steht 4D Entwicklern eine breite Palette an Werkzeugen zur Verfügung, um die Abarbeitung ein- und ausgehender HTTP-Anfragen vollkommen eigenständig zu gestalten. Die Übersicht zeigt die verschiedenen Werkzeuge:

Nachfolgendes Beispiel zeigt die Verwendung von WEB SEND RAW DATA mit der Option gestückelt. Die Daten – eine Folge von Nummern – wird in 100 Stücken gesendet, die unmittelbar in einer Schleife erzeugt werden. Beachten Sie, dass der Header der Antwort nicht explizit gesetzt wird. Der Befehl sendet ihn automatisch und fügt das Feld transfer-encoding: chunked ein, da der Parameter * verwendet wird.

 C_LONGINT($cpt)
 C_BLOB($my_blob)
 C_TEXT($output)
 
 For($cpt;1;100)
    $output:="["+String($cpt)+"]"
    TEXT TO BLOB($output;$my_blob;UTF8 text without length)
    WEB SEND RAW DATA($my_blob;*)
 End for



Siehe auch 

WEB GET HTTP BODY
WEB GET HTTP HEADER

 
EIGENSCHAFTEN 

Produkt: 4D
Thema: Web Server
Nummer: 815

This command can be run in preemptive processes

 
GESCHICHTE 

Erstellt: 4D 2004
Umbenannt: 4D v13

 
ARTIKELVERWENDUNG

4D Programmiersprache ( 4D v16)
4D Programmiersprache ( 4D v16.1)
4D Programmiersprache ( 4D v16.2)
4D Programmiersprache ( 4D v16.3)