Paket | flash.media |
Klasse | public class AVURLStream |
Vererbung | AVURLStream URLStream EventDispatcher Object |
Sprachversion: | ActionScript 3.0 |
Laufzeitversionen: | AIR 1.0, Flash Player 9, Flash Lite 4 |
Die Lesevorgänge in „URLStream“ sind ungeblockt. Das heißt, dass Sie die Eigenschaft bytesAvailable
verwenden müssen, um zu ermitteln, ob genügend Daten vorhanden sind, bevor Sie den Lesevorgang starten. Wenn nicht genügend Daten vorhanden sind, wird eine EOFError
-Ausnahme ausgelöst.
Alle Binärdaten werden standardmäßig im Big Endian-Format kodiert, wobei das höchstwertige Byte an erster Stelle steht.
Für URL-Downloads mit der URLStream-Klasse gelten dieselben Sicherheitsregeln wie für URLLoader-Objekte. Richtliniendateien können nach Bedarf heruntergeladen werden. Lokale Dateisicherheitsregeln werden erzwungen, und ggf. werden Sicherheitswarnungen ausgegeben.
Verwandte API-Elemente
URLRequest
Eigenschaft | Definiert von | ||
---|---|---|---|
bytesAvailable : uint [schreibgeschützt]
Gibt für die zum Lesen verfügbaren Daten im Eingabepuffer die Anzahl der Byte an. | URLStream | ||
connected : Boolean [schreibgeschützt]
Gibt an, ob dieses URLStream-Objekt zurzeit verbunden ist. | URLStream | ||
constructor : Object
Ein Verweis auf das Klassenobjekt oder die Konstruktorfunktion für eine angegebene Objektinstanz. | Object | ||
cookieHeader : String [Nur Schreiben] | AVURLStream | ||
endian : String
Gibt die Byte-Reihenfolge der Daten an. | URLStream | ||
objectEncoding : uint
Steuert die beim Schreiben oder Lesen eines Objekts verwendete Version von Action Message Format (AMF). | URLStream |
Methode | Definiert von | ||
---|---|---|---|
addEventListener(type:String, listener:Function, useCapture:Boolean = false, priority:int = 0, useWeakReference:Boolean = false):void
Registriert ein Ereignis-Listener-Objekt bei einem EventDispatcher-Objekt, sodass der Listener über ein Ereignis benachrichtigt wird. | EventDispatcher | ||
Schließt den Stream unmittelbar und bricht den Download-Vorgang ab. | URLStream | ||
Sendet ein Ereignis in den Ereignisablauf. | EventDispatcher | ||
Überprüft, ob das EventDispatcher-Objekt Listener für einen bestimmten Ereignistyp registriert hat. | EventDispatcher | ||
Gibt an, ob für ein Objekt eine bestimmte Eigenschaft definiert wurde. | Object | ||
Gibt an, ob eine Instanz der Object-Klasse in der Prototypkette des Objekts vorhanden ist, das als Parameter angegeben wurde. | Object | ||
[override]
Startet den Download der im Parameter „request“ angegebenen URL. | AVURLStream | ||
Gibt an, ob die angegebene Eigenschaft vorhanden ist und durchlaufen werden kann. | Object | ||
Liest einen booleschen Wert aus dem Stream. | URLStream | ||
Liest ein Byte mit Vorzeichen aus dem Stream. | URLStream | ||
Liest „length“-Byte Daten aus dem Stream. | URLStream | ||
Liest eine Gleitkommazahl nach IEEE 754 mit doppelter Genauigkeit aus dem Stream. | URLStream | ||
Liest eine Gleitkommazahl nach IEEE 754 mit einfacher Genauigkeit aus dem Stream. | URLStream | ||
Liest eine 32-Bit-Ganzzahl mit Vorzeichen aus dem Stream. | URLStream | ||
Liest einen Multibyte-String der angegebenen Länge unter Verwendung des angegebenen Zeichensatzes vom Bytedatenstream. | URLStream | ||
readObject():*
Liest ein im Action Message Format (AMF) kodiertes Objekt vom Socketserver. | URLStream | ||
Liest eine 16-Bit-Ganzzahl mit Vorzeichen aus dem Stream. | URLStream | ||
Liest ein Byte ohne Vorzeichen aus dem Stream. | URLStream | ||
Liest eine 32-Bit-Ganzzahl ohne Vorzeichen aus dem Stream. | URLStream | ||
Liest eine 16-Bit-Ganzzahl ohne Vorzeichen aus dem Stream. | URLStream | ||
Liest einen UTF-8-String aus dem Bytestream. | URLStream | ||
Liest eine Folge von length-UTF-8-Byte aus dem Bytestream und gibt einen String zurück. | URLStream | ||
Entfernt einen Listener aus dem EventDispatcher-Objekt. | EventDispatcher | ||
Legt die Verfügbarkeit einer dynamischen Eigenschaft für Schleifenoperationen fest. | Object | ||
Gibt die Stringdarstellung dieses Objekts zurück, formatiert entsprechend den Konventionen des Gebietsschemas. | Object | ||
Gibt das angegebene Objekt als String zurück. | Object | ||
Gibt den Grundwert des angegebenen Objekts zurück. | Object | ||
Überprüft, ob bei diesem EventDispatcher-Objekt oder bei einem seiner Vorgänger ein Ereignis-Listener für einen bestimmten Ereignistyp registriert ist. | EventDispatcher |
cookieHeader | Eigenschaft |
load | () | Methode |
override public function load(request:URLRequest):void
Sprachversion: | ActionScript 3.0 |
Laufzeitversionen: | AIR 1.0, Flash Player 9, Flash Lite 4 |
Startet den Download der im Parameter request
angegebenen URL.
Hinweis: Enthält eine geladene Datei Nicht-ASCII-Zeichen (wie sie z. B. in vielen Sprachen außerhalb des englischen Sprachraums vorkommen), wird empfohlen, dass Sie die Datei im Format UTF-8 oder UTF-16 und nicht in einem Unicode-fremden Format (z. B. ASCII) speichern.
Wenn der Ladevorgang unmittelbar fehlschlägt, wird eine IOError- oder eine SecurityError-Ausnahme (mit dem lokalen Dateisicherheitsfehler) mit der Beschreibung des Fehlers ausgegeben. Andernfalls wird ein open
-Ereignis ausgelöst, wenn der URL-Download erfolgreich gestartet wird, bzw. ein Fehlerereignis, wenn ein Fehler auftritt.
Standardmäßig müssen die aufrufende SWF-Datei und die von Ihnen geladene URL in genau der gleichen Domäne sein. Eine SWF-Datei unter www.adobe.com kann beispielsweise nur Daten laden, die sich ebenfalls unter www.adobe.com befinden. Legen Sie eine URL-Richtliniendatei auf dem Server ab, der die Daten hostet, um Daten aus einer anderen Domäne zu laden.
In Flash Player können Sie keine Verbindung mit normalerweisen reservierten Ports herstellen. Eine vollständige Liste der gesperrten Ports finden Sie unter „Beschränken von Netzwerk-APIs“ im ActionScript 3.0 Entwicklerhandbuch.
In Flash Player können Sie eine SWF-Datei daran hindern, diese Methode zu verwenden, indem Sie den allowNetworking
-Parameter des object
- und embed
-Tags auf der HTML-Seite setzen, die den SWF-Inhalt enthält.
Wenn Sie in Flash Player 10 und höher und in AIR 1.5 und höher einen Multipart-Content-Type (z. B. „multipart/form-data“) verwenden, der ein Upload enthält (angegeben durch einen „filename“-Parameter in einem „content-disposition“-Header innerhalb des POST-Body), unterliegt die POST-Methode den auf Uploads angewendeten Sicherheitsregeln:
- Der POST-Vorgang muss als Reaktion auf eine durch den Benutzer initiierte Aktion, z. B. Mausklick oder Tastendruck, erfolgen.
- Ist die POST-Methode domänenübergreifend (das POST-Ziel befindet sich auf einem anderen Server als die SWF-Datei, die die POST-Anforderung sendet), so muss der Zielserver eine URL-Richtliniendatei bereitstellen, die den domänenübergreifenden Zugriff erlaubt.
Für alle mehrteiligen Content-Typen muss ebenfalls die Syntax nach Standard RFC2046 gültig sein. Scheint die Syntax ungültig zu sein, so unterliegt die POST-Methode den Sicherheitsregeln für Uploads.
Diese Regeln gelten auch für AIR-Inhalt in anwendungsfremden Sandboxen. In Adobe AIR dagegen ist Inhalt in der Anwendungssandbox (mit der AIR-Anwendung installierter Inhalt) nicht durch diese Sicherheitseinschränkungen beschränkt.
Weitere Informationen zum Thema Sicherheit finden Sie im Flash Player Developer Center im Abschnitt Sicherheit.
In AIR kann sich ein URLRequest-Objekt für das httpResponse
-Statusereignis registrieren. Anders als das httpStatus
-Ereignis wird das httpResponseStatus
-Ereignis ausgelöst, bevor Antwortdaten vorliegen. Außerdem enthält das httpResponseStatus
-Ereignis Werte für die Eigenschaften responseHeaders
und responseURL
(die für ein httpStatus
-Ereignis nicht definiert sind). Beachten Sie, dass das Ereignis httpResponseStatus
(falls vorhanden) vor (und zusätzlich zu) jedem complete
- oder error
-Ereignis gesendet wird.
Wenn es einen httpResponseStatus
Ereignis-Listener gibt, wird der Rumpf der Antwortmeldung immer gesendet, und HTTP-Statuscodeantworten resultierten immer in einem complete
-Ereignis. Dies ist unabhängig davon wahr, ob der HTTP-Antwortstatuscode einen Erfolg oder einen Fehler anzeigt.
Wenn es in AIR keine httpResponseStatus
-Ereignis-Listener gibt, ist das Verhalten basierend auf der SWFAIR-Version unterschiedlich:
- Bei SWF 9-Inhalten wird der Hauptteil der HTTP-Antwortnachricht nur dann gesendet, wenn der HTTP-Antwortstatuscode Erfolg anzeigt. Andernfalls (wenn ein Fehler vorliegt) wird kein Rumpf gesendet und das URLRequest-Objekt löst ein IOError-Ereignis aus.
- Bei SWF 10-Inhalten wird der Hauptteil der HTTP-Antwortnachricht immer gesendet. Wenn ein Fehler vorliegt, löst das URLRequest-Objekt ein IOError-Ereignis aus.
Parameter
request:URLRequest — Ein URLRequest-Objekt, das die herunterzuladende URL angibt. Wenn der Wert dieses Parameters oder der Eigenschaft URLRequest.url des übergebenen URLRequest-Objekts null ist, gibt die Anwendung einen Nullzeiger-Fehler aus.
|
Ereignisse
complete: — Wird nach dem erfolgreichen Laden von Daten ausgelöst. Wenn es einen httpResponseStatus -Ereignis-Listener gibt, löst das URLRequest-Objekt auch ein complete -Ereignis aus, unabhängig davon, ob der HTTP-Antwortstatuscode einen Erfolg oder einen Fehler angibt.
| |
httpStatus: — Wenn der Zugriff über HTTP erfolgt und die aktuelle Umgebung den Empfang von Statuscodes unterstützt, werden diese Ereignisse möglicherweise zusätzlich zu allen complete - oder error -Ereignissen empfangen.
| |
httpResponseStatus: — Wird ausgelöst, wenn ein Aufruf der load() -Methode versucht, über HTTP auf Daten zuzugreifen und Adobe AIR den Statuscode für die Anforderung erkennen und zurückgeben kann.
| |
ioError: — Der Ladevorgang konnte nicht abgeschlossen werden.
| |
open: — Wird beim Start eines Ladevorgangs ausgelöst.
| |
securityError: — Bei einem Ladevorgang wurde versucht, Daten von einem Server außerhalb der Sicherheitssandbox der aufrufenden Funktion abzurufen. Sie können dies umgehen, indem Sie eine Richtliniendatei auf dem Server verwenden.
|
Auslöser
ArgumentError — Bestimmte nicht zulässige HTTP-Anforderungsheader sind möglicherweise in URLRequest.requestHeader -Objekten nicht enthalten. Weitere Informationen finden Sie in der Beschreibung der URLRequestHeader-Klasse.
| |
MemoryError — Dieser Fehler kann folgende Ursachen haben:
| |
SecurityError — Über lokale nicht vertrauenswürdige SWF-Dateien kann keine Verbindung mit dem Internet hergestellt werden. Sie können dieses Problem umgehen, indem Sie diese SWF-Datei neu als lokal mit Netzwerk oder als vertrauenswürdig klassifizieren.
| |
SecurityError — Sie versuchen, eine Verbindung mit einem normalerweise reservierten Port herzustellen. Eine vollständige Liste der gesperrten Ports finden Sie unter „Beschränken von Netzwerk-APIs“ im ActionScript 3.0 Entwicklerhandbuch.
|
Tue Jun 12 2018, 10:04 AM Z