Real-Time Messaging Protocol - Real-Time Messaging Protocol

Real-Time Messaging Protocol (RTMP) byl původně a proprietární protokol vyvinutý uživatelem Macromedia pro streamování audio, video a data přes internet, mezi a Blikat hráč a server. Společnost Macromedia nyní vlastní Adobe, která vydala neúplnou verzi specifikace protokolu pro veřejné použití.

Protokol RTMP má několik variant:

  1. Správný RTMP, „prostý“ protokol, který funguje navíc protokol kontroly přenosu (TCP) a ve výchozím nastavení používá číslo portu 1935.
  2. RTMPS, což je RTMP přes a Zabezpečení transportní vrstvy (TLS / SSL) připojení.
  3. RTMPE, což je RTMP šifrované pomocí vlastního bezpečnostního mechanismu společnosti Adobe. Zatímco podrobnosti implementace jsou proprietární, mechanismus používá standardní kryptografické primitivy.[1]
  4. RTMPT, což je zapouzdřený v rámci HTTP požadavky na procházení branami firewall. RTMPT se často nalézá s využitím požadavků typu cleartext na TCP porty 80 a 443 obejít většinu filtrování podnikového provozu. Zapouzdřená relace může v sobě nést prosté pakety RTMP, RTMPS nebo RTMPE.
  5. RTMFP, což je RTMP nad Protokol uživatele Datagram (UDP) namísto TCP, nahrazující RTMP Chunk Stream. Zabezpečený Protokol toku médií v reálném čase sada byla vyvinuta společností Adobe Systems a umožňuje koncovým uživatelům vzájemné připojení a přímou komunikaci (P2P).

Zatímco primární motivací pro RTMP měl být protokol pro přehrávání videa Flash, používá se také v některých dalších aplikacích, například Adobe LiveCycle Data Services ES.

Základní operace

RTMP je protokol založený na TCP, který udržuje trvalé připojení a umožňuje komunikaci s nízkou latencí. Aby bylo možné doručovat streamy plynule a přenášet co nejvíce informací, rozděluje streamy na fragmenty a jejich velikost se dynamicky sjednává mezi klientem a serverem. Někdy je zachována beze změny; výchozí velikosti fragmentů jsou 64 bajtů pro zvuková data a 128 bajtů pro video data a většinu ostatních datových typů. Fragmenty z různých proudů pak mohou být prokládány, a multiplexovaný přes jediné připojení. U delších datových bloků tak protokol nese na jeden fragment pouze jednobajtovou hlavičku, takže vznikne velmi málo nad hlavou. V praxi se však jednotlivé fragmenty obvykle neprokládají. Místo toho se prokládání a multiplexování provádí na úrovni paketů, přičemž pakety RTMP napříč několika různými aktivními kanály jsou prokládány takovým způsobem, aby bylo zajištěno, že každý kanál splňuje svou šířku pásma, latenci a další požadavky na kvalitu služby. Pakety prokládané tímto způsobem jsou považovány za nedělitelné a nejsou prokládány na úrovni fragmentů.

RTMP definuje několik virtuálních kanálů, na kterých lze odesílat a přijímat pakety a které fungují nezávisle na sobě. Například existuje kanál pro zpracování požadavků a odpovědí RPC, kanál pro data video streamu, kanál pro data audio streamu, kanál pro mimopásmové kontrolní zprávy (vyjednávání o velikosti fragmentu atd.) Atd. . Během typické relace RTMP může být současně aktivních několik kanálů současně. Při kódování dat RTMP se vygeneruje záhlaví paketu. Záhlaví paketu mimo jiné určuje ID kanálu, na který má být odeslán, časové razítko, kdy byl vygenerován (je-li to nutné) a velikost užitečného zatížení paketu. Po této hlavičce následuje skutečný obsah užitečného obsahu paketu, který je fragmentován podle aktuálně dohodnuté velikosti fragmentu před odesláním přes připojení. Samotné záhlaví paketu není nikdy fragmentované a jeho velikost se nezapočítává do dat v prvním fragmentu paketu. Jinými slovy, fragmentaci podléhá pouze skutečné užitečné zatížení paketu (mediální data).

Na vyšší úrovni se RTMP zapouzdřuje MP3 nebo AAC audio a Video FLV1 multimediální streamy a můžete provádět vzdálená volání procedur (RPC) pomocí Formát zprávy o akci. Jakékoli požadované služby RPC jsou prováděny asynchronně pomocí jediného modelu požadavku / odezvy klient / server, takže není nutná komunikace v reálném čase.[je zapotřebí objasnění ][2][3]

Šifrování

Relace RTMP mohou být šifrovány pomocí jedné ze dvou metod:

  • Používání průmyslového standardu TLS / SSL mechanismy. Základní relace RTMP je jednoduše zabalena do normální relace TLS / SSL.
  • Použití RTMPE, které zabalí relaci RTMP do lehčí šifrovací vrstvy.

Tunelování HTTP

V RTMP Tunneled (RTMPT) jsou data RTMP zapouzdřený a vyměnit prostřednictvím HTTP a zprávy od klienta (v tomto případě přehrávače médií) jsou adresovány na port 80 (výchozí pro HTTP) na serveru.

Zatímco zprávy v RTMPT jsou větší než ekvivalentní netunelované zprávy RTMP kvůli hlavičkám HTTP, RTMPT může usnadnit použití RTMP ve scénářích, kde by jinak nebylo možné použít netunelovaný RTMP, například když je klient pozadu A firewall který blokuje odchozí provoz bez HTTP a HTTPS.

Protokol funguje tak, že se odesílají příkazy prostřednictvím adresy POST URL a zprávy AMF prostřednictvím těla POST. Příkladem je

POST / otevřený / 1 HTTP / 1.1

pro otevření připojení.

Specifikační dokument a patentová licence

Společnost Adobe vydala specifikaci pro verzi 1.0 protokolu ze dne 21. prosince 2012.[4] Webová vstupní stránka vedoucí k této specifikaci uvádí, že „Ve prospěch zákazníků, kteří chtějí chránit jejich obsah, neobsahuje otevřená specifikace RTMP jedinečná zabezpečená opatření RTMP společnosti Adobe“.[5]

Dokument doprovázející specifikaci Adobe uděluje „nevýhradní, bez licenčních poplatků, nepřenosné, nesublicencovatelné, osobní, celosvětové“ patentová licence ke všem implementacím protokolu se dvěma omezeními: jedno zakazuje použití pro zachycení streamovaných dat („jakákoli technologie, která zachytí streamovaný video, audio a / nebo datový obsah pro uložení v jakémkoli zařízení nebo médiu“) a další zakazuje obcházení „technologického opatření na ochranu zvukového, obrazového a / nebo datového obsahu, včetně jakýchkoli zabezpečených opatření RTMP společnosti Adobe “.[6]

Patenty a související soudní spory

Stefan Richter, autor některých knih o Flashi, v roce 2008 poznamenal, že zatímco Adobe je vágní ohledně toho, jaké patenty se vztahují na RTMP, US patent 7246356 se zdá být jedním z nich.[2]

V roce 2011 společnost Adobe žalovala společnost Wowza Media Systems, která mimo jiné tvrdila, že došlo k porušení jejich patentů RTMP.[7][8][9] V roce 2015 společnosti Adobe a Wowza oznámily, že soudní spory byly urovnány a zamítnuty s předsudky.[10]

Struktura paketů

RTMP paketový diagram

Pakety jsou odesílány přes připojení TCP, které je navázáno jako první mezi klientem a serverem. Obsahují záhlaví a tělo, které je v případě připojení a řídicích příkazů kódováno pomocí Formát zprávy o akci (AMF). Záhlaví je rozděleno na Základní záhlaví (zobrazeno jako oddělené od ostatních v diagramu) a Záhlaví zprávy bloku. Základní záhlaví je jedinou konstantní částí paketu a obvykle se skládá z jediné kompozitní byte, kde dva nejvýznamnější bity jsou Chunk Type (fmt ve specifikaci) a zbytek tvoří ID streamu. V závislosti na hodnotě prvního lze některá pole v záhlaví zprávy vynechat a jejich hodnotu odvodit z předchozích paketů, zatímco v závislosti na hodnotě druhého lze základní záhlaví rozšířit o jeden nebo dva další bajty (jako v případě diagramu, který má celkem tři bajty (c)). Pokud je hodnota zbývajících šesti bitů z Základní záhlaví (BH) (nejméně významné) je 0, pak BH má dva bajty a představuje od ID toku 64 do 319 (64 + 255); pokud je hodnota 1, pak BH jsou tři bajty (s posledními dvěma bajty kódovanými jako 16bitový Little Endian) a představuje od ID toku 64 do 65599 (64 + 65535); pokud je hodnota 2, pak BH je jeden bajt a je vyhrazen pro řídicí zprávy a příkazy protokolu na nízké úrovni. Záhlaví zprávy bloku obsahuje informace o metadatech, jako je velikost zprávy (měřeno v bajtech), Delta časové značky a Typ zprávy. Tato poslední hodnota je jeden bajt a definuje, zda je paket audio, video, příkaz nebo „nízkoúrovňový“ RTMP paket, jako je RTMP Ping.

Níže je uveden příklad zachycený, když klient Flash provede následující kód:

var proud:NetStream = Nový NetStream(connectionObject);

vygeneruje se následující blok:

Hex kódASCII
03 00 0B 68 00 00 19 14 00 00 00 00 02 00 0C 63 72 65 61 74 65 53 74 72 65 61 6D 00 40 00 00 00 00 00 00 00 05 ␀ @ I ␀ ␀ ␙ ␀ ␀ ␀ ␀ ␀ ␌ c r e a t e S t r e a m ␀ @ ␀ ␀ ␀ ␀ ␀ ␀ ␀ ␅

Paket začíná na Základní záhlaví jednoho bajtu (0x03), kde jsou dva nejvýznamnější bity (b00000011) definujte typ hlavičky bloku 0, zatímco zbytek (b00000011) definujte ID proudu bloku 3. Čtyři možné hodnoty typu záhlaví a jejich význam jsou:

  • b00 = 12bajtová hlavička (plná hlavička).
  • b01 = 8 bajtů - jako typ b00. bez ID zprávy (4 poslední bajty).
  • b10 = 4 bajty - základní záhlaví a časové razítko (3 bajty) jsou zahrnuty.
  • b11 = 1 bajt - zahrnuje pouze základní záhlaví.

Poslední typ (b11) se vždy používá v případě agregovaných zpráv, kde ve výše uvedeném příkladu bude druhá zpráva začínat ID 0xC3 (b11000011) a znamenalo by, že všechna pole záhlaví zprávy by měla být odvozena od zprávy s ID proudu 3 (což by byla zpráva přímo nad ním). Šest nejméně významných bitů, které tvoří ID proudu, může nabývat hodnot mezi 3 a 63. Některé hodnoty mají zvláštní význam, například 1, který znamená rozšířený formát ID, v takovém případě budou následovat dva bajty. Hodnota dva je pro zprávy na nízké úrovni, jako je Ping a Nastavit šířku pásma klienta.

Další bajty záhlaví RTMP (včetně hodnot v příkladovém paketu výše) jsou dekódovány následovně:

  • byte # 1 (0x03) = Typ záhlaví bloku.
  • byte # 2-4 (0x000b68) = delta časového razítka.
  • byte # 5-7 (0x000019) = Délka paketu - v tomto případě je to 0x000019 = 25 bajtů.
  • byte # 8 (0x14) = ID typu zprávy - 0x14 (20) definuje kódování AMF0 příkaz zpráva.
  • byte # 9-12 (0x00000000) = ID streamu zprávy. To je v pořadí malého endianu

Bajt ID typu zprávy definuje, zda paket obsahuje audio / video data, vzdálený objekt nebo příkaz. Některé možné hodnoty pro:

  • 0x01 = Nastavit zprávu o velikosti paketu.
  • 0x02 = Přerušit.
  • 0x03 = Potvrdit.
  • 0x04 = Řídicí zpráva.
  • 0x05 = Šířka pásma serveru
  • 0x06 = šířka pásma klienta.
  • 0x07 = Virtuální ovládání.
  • 0x08 = zvukový paket.
  • 0x09 = Video paket.
  • 0x0F = Data rozšířena.
  • 0x10 = kontejner rozšířen.
  • 0x11 = Příkaz rozšířen (příkaz typu AMF3).
  • 0x12 = Data (Invoke (onMetaData info is sent as such)).
  • 0x13 = Kontejner.
  • 0x14 = Příkaz (příkaz typu AMF0).
  • 0x15 = UDP
  • 0x16 = agregovat
  • 0x17 = přítomný

Po záhlaví 0x02 označuje řetězec o velikosti 0x000C a hodnotách 0x63 0x72 ... 0x6D (příkaz „createStream“). Následně máme 0x00 (číslo), což je ID transakce hodnoty 2.0. Poslední bajt je 0x05 (null), což znamená, že neexistují žádné argumenty.

Vyvolat strukturu zprávy (0x14, 0x11)

Některé z výše uvedených typů zpráv, například Ping a Nastavit šířku pásma klient / server, jsou považovány za zprávy protokolu RTMP nízké úrovně, které nepoužívají formát kódování AMF. Zprávy příkazů na druhé straně, ať už AMF0 (typ zprávy 0x14) nebo AMF3 (0x11), používají formát a mají obecný formulář uvedený níže:

(Řetězec)  (Číslo)  (Smíšené)  např. Null, String, Object: {key1: value1, key2: value2 ...}

ID transakce se používá pro příkazy, které mohou mít odpověď. Hodnotou může být buď řetězec jako v příkladu výše, nebo jeden nebo více objektů, každý složený ze sady párů klíč / hodnota, kde jsou klíče vždy kódovány jako řetězce, zatímco hodnotami může být jakýkoli datový typ AMF, včetně komplexních typů jako pole.

Struktura řídicích zpráv (0x04)

Řídicí zprávy nejsou kódovány AMF. Začínají s ID proudu 0x02, což znamená úplnou hlavičku (typ 0), a mají typ zprávy 0x04. Za záhlavím následuje šest bytů, které jsou interpretovány takto:

  • # 0-1 - Typ ovládání.
  • # 2-3 - Druhý parametr (to má význam v konkrétních typech řízení)
  • # 4-5 - Třetí parametr (stejný)

První dva bajty těla zprávy definují typ Ping, který lze zjevně[11] vezměte šest možných hodnot.

  • Typ 0 - Vymazat stream: Odesláno, když je navázáno připojení a neobsahuje žádná další data
  • Typ 1 - Vymažte vyrovnávací paměť.
  • Typ 2 - Stream Dry.
  • Typ 3 - čas vyrovnávací paměti klienta. Třetí parametr udržuje hodnotu v milisekundách.
  • Typ 4 - Resetujte stream.
  • Typ 6 - Ping klienta ze serveru. Druhým parametrem je aktuální čas.
  • Typ 7 - Pongová odpověď od klienta. Druhým parametrem je čas, kdy klient obdrží Ping.
  • Typ 8 - požadavek UDP.
  • Typ 9 - UDP Response.
  • Typ 10 - Limit šířky pásma.
  • Typ 11 - šířka pásma.
  • Typ 12 - Šířka pásma škrticí klapky.
  • Typ 13 - Stream vytvořen.
  • Typ 14 - Stream byl smazán.
  • Typ 15 - Nastavit přístup pro čtení.
  • Typ 16 - Nastavit přístup pro zápis.
  • Typ 17 - Streamování meta požadavku.
  • Typ 18 - Stream Meta Response.
  • Typ 19 - Získejte hranice segmentu.
  • Typ 20 - Nastavit hranici segmentu.
  • Typ 21 - Zapnuto Odpojit.
  • Typ 22 - Nastavit kritický odkaz.
  • Typ 23 - Odpojit.
  • Zadejte 24 - Hash Update.
  • Typ 25 - Hash Timeout.
  • Typ 26 - Hash Request.
  • Typ 27 - Hash Response.
  • Typ 28 - Zkontrolujte šířku pásma.
  • Typ 29 - Nastavte přístup k ukázce zvuku.
  • Type 30 - Set Video Sample Access.
  • Typ 31 - Začátek škrticí klapky.
  • Typ 32 - Konec škrticí klapky.
  • Typ 33 - DRM Upozornit.
  • Typ 34 - RTMFP Sync.
  • Typ 35 - Dotaz IHello.
  • Typ 36 - Dopředu IHello.
  • Typ 37 - Přesměrování IHello.
  • Typ 38 - Upozornit EOF.
  • Typ 39 - Proxy Pokračovat.
  • Typ 40 - Proxy Remove Upstream.
  • Typ 41 - RTMFP Set Keepalives.
  • Typ 46 - Segment nebyl nalezen.

Pong je název odpovědi na Ping s použitými hodnotami, jak je vidět výše.

Struktura zpráv ServerBw / ClientBw (0x05, 0x06)

To se týká zpráv, které mají co do činění s bitovou rychlostí up-stream klienta a down-stream serveru. Tělo se skládá ze čtyř bajtů ukazujících hodnotu šířky pásma s možným rozšířením o jeden bajt, které nastavuje typ limitu. Může mít jednu ze tří možných hodnot, které mohou být: tvrdé, měkké nebo dynamické (měkké nebo tvrdé).

Nastavit velikost bloku (0x01)

Hodnota přijatá ve čtyřech bajtech těla. Výchozí hodnota 128 bytů existuje a zpráva je odeslána pouze v případě, že je požadována změna.

Protokol

Diagram handshake RTMP

Potřesení rukou

Po navázání připojení TCP je navázáno připojení RTMP, které nejprve provede handshake prostřednictvím výměny tří paketů z každé strany (v oficiální dokumentaci se také označuje jako Chunks). V oficiální specifikaci jsou označovány jako C0-2 pro klientem zasílané pakety a S0-2 pro stranu serveru a nelze je zaměňovat s RTMP pakety, které lze vyměnit až po dokončení handshake. Tyto pakety mají vlastní strukturu a C1 obsahuje pole, které nastavuje časovou značku „epochy“, ale protože ji lze nastavit na nulu, jak se to dělá v implementacích třetích stran, paket lze zjednodušit. Klient inicializuje připojení odesláním paketu C0 s konstantní hodnotou 0x03 představující aktuální verzi protokolu. Následuje rovně s C1 bez čekání na první přijetí S0, který obsahuje 1536 bajtů, přičemž první čtyři představují časovou značku epochy, druhé čtyři jsou všechny 0 a zbytek je náhodný (a který lze u třetí strany nastavit na 0 implementace). C2 a S2 jsou ozvěnou S1 a C1, s výjimkou, kdy druhé čtyři bajty jsou časem, kdy byla příslušná zpráva přijata (místo 0). Po přijetí C2 a S2 je podání ruky považováno za úplné.

Připojit

V tomto okamžiku mohou klient a server vyjednat připojení výměnou AMF kódováno zprávy. Patří mezi páry klíč-hodnota, které se vztahují k proměnným, které jsou potřebné pro navázání spojení. Příklad zprávy od klienta je:

(Vyvolat) "připojit"(Transakce ID) 1.0(Objekt1) { aplikace: "vzorek", flashVer: „MAC 10,2153,2“, swfUrl: nula,              tcUrl: „rtmpt: //127.0.0.1/sample“, fpad: Nepravdivé,              schopnosti: 9947.75 , audiokodeky: 3191, videokodeky: 252,              funkce videa: 1 , pageUrl: nula, kódování objektu: 3.0 }

Server Flash Media Server a další implementace využívá koncept „aplikace“ ke koncepčnímu definování kontejneru pro audio / video a další obsah implementovaný jako složka v kořenovém adresáři serveru, která obsahuje mediální soubory, které mají být streamovány. První proměnná obsahuje název této aplikace jako „vzorek“, což je název poskytnutý serverem Wowza pro jejich testování. The flashVer řetězec je stejný jako vrácený skriptem Action getversion () funkce. The audiokodek a videokodek jsou kódovány jako čtyřhra a jejich význam lze najít v původní specifikaci. Totéž platí pro funkce videa proměnná, která je v tomto případě samozřejmou konstantou SUPPORT_VID_CLIENT_SEEK. Zvláštního zájmu je kódování objektu který definuje, zda zbytek komunikace bude využívat rozšířené AMF3 formát nebo ne. Jelikož je aktuální výchozí verze 3, musí být klientovi Flash v kódu skriptu akce výslovně řečeno, aby použil AMF0, pokud je to požadováno. Server poté odpoví posloupností zpráv ServerBW, ClientBW a SetPacketSize, nakonec následovanou Invoke, s ukázkovou zprávou.

(Vyvolat) "_výsledek"(transakce ID) 1.0(Objekt1) { fmsVer: „FMS / 3,5,5,2004“, schopnosti: 31.0, režimu: 1.0 }(Objekt2) { úroveň: "postavení", kód: „NetConnection.Connect.Success“,                   popis: „Připojení bylo úspěšné“,                   data: (pole) { verze: "3,5,5,2004" },                   clientId: 1728724019, kódování objektu: 3.0 }

Některé z výše uvedených hodnot jsou serializovány do vlastností obecného objektu Action-script Object, který je poté předán posluchači událostí NetConnection. The clientId vytvoří číslo relace, která má být spuštěna připojením. Kódování objektu se musí shodovat s dříve nastavenou hodnotou.

Přehrát video

Chcete-li spustit videostream, klient odešle volání „createStream“ následované zprávou ping následovanou vyvoláním „přehrávání“ s názvem souboru jako argumentem. Server poté odpoví řadou příkazů „onStatus“ následovaných video daty zapouzdřenými ve zprávách RTMP.

Po navázání připojení je médium odesláno zapouzdřením obsahu Značky FLV do zpráv RTMP typu 8 a 9 pro audio a video.

Tunelování HTTP (RTMPT)

To se týká verze protokolu tunelového propojení HTTP. Komunikuje přes port 80 a předává AMF data uvnitř požadavku HTTP POST a odpovědí. Pořadí pro připojení je následující:

POŠTA / fcs / ident2 HTTP/1.1Typ obsahu: application / x-fcs  r  nHTTP / 1.0 404 nebyl nalezen
POŠTA / otevřeno / 1 HTTP/1.1Typ obsahu: application / x-fcs  r  nHTTP / 1.1 200 OKContent-Type: application / x-fcs  r  n 1728724019

První požadavek má / fcs / ident2 cesta a správná odpověď je chyba 404 nenalezena. Klient poté odešle požadavek / open / 1, kde musí server odpovědět 200 ok připojením náhodného čísla, které bude použito jako identifikátor relace pro uvedenou komunikaci. V tomto příkladu je v těle odpovědi vráceno 1728724019.

POŠTA / idle / 1728724019/0 HTTP/1.1HTTP / 1.1 200 OK   0x01

Od této chvíle / idle / / je požadavek na výzvu, kde bylo ID relace vygenerováno a vráceno ze serveru a sekvence je jen číslo, které se zvyšuje o jeden pro každý požadavek. Odpovídající odpověď je 200 OK s celým číslem vráceným v těle, které značí časový interval. AMF data jsou odesílána prostřednictvím / send / /

Softwarové implementace

RTMP je implementován v těchto třech fázích:

  • Živý kodér videa
  • Živý a streamovací server na vyžádání
  • Živý klient a klient na vyžádání

rtmpdump

Nástroj příkazového řádku klienta RTMP s otevřeným zdrojovým kódem rtmpdump je navržen tak, aby přehrával nebo ukládal na disk celý stream RTMP včetně RTMPE protokol, který společnost Adobe používá k šifrování. RTMPdump běží na Linuxu, Androidu, Solarisu, Mac OS Xa většina ostatních operačních systémů odvozených od Unixu a také Microsoft Windows. Původně podporující všechny verze 32bitových Windows včetně Windows 98, od verze 2.2 bude software fungovat pouze ve Windows XP a novějších (i když dřívější verze zůstávají plně funkční).

Balíčky rtmpdump sada softwaru je k dispozici v hlavních úložištích open-source (distribuce GNU / Linux). Patří mezi ně front-endové aplikace „rtmpdump“, „rtmpsrv“ a „rtmpsuck“.

Vývoj RTMPdump byl znovu zahájen v říjnu 2009 mimo USA na MPlayer stránky.[12] Funkce aktuální verze výrazně vylepšila funkčnost a byla přepsána, aby využila výhod systému Programovací jazyk C.. Hlavní funkce byla zabudována zejména do knihovny (librtmp), kterou lze snadno použít v jiných aplikacích. Vývojáři RTMPdump také napsali podporu pro librtmp pro MPlayer, FFmpeg, XBMC, kučera, VLC a řada dalších open source softwarových projektů. Použití librtmp poskytuje těmto projektům plnou podporu RTMP ve všech jeho variantách bez dalšího úsilí o vývoj.

FLVstreamer

FLVstreamer je vidlice RTMPdump, bez kódu, který Adobe tvrdí, že porušuje DMCA v USA. Toto bylo vyvinuto jako reakce na pokus Adobe v roce 2008 potlačit RTMPdump. FLVstreamer je klient RTMP, který uloží proud zvukového nebo obrazového obsahu z libovolného serveru RTMP na disk, pokud v proudu není povoleno šifrování (RTMPE).

Viz také

Reference

  1. ^ „RTMPE“. Nápověda k aplikaci Adobe Flash Lite 4. Adobe. Citováno 29. prosince 2013.
  2. ^ A b „TheRealTimeWeb.com: Adobe Patents RTMP“. www.therealtimeweb.com.
  3. ^ „Používání služeb RPC ve službě Flex Data Services 2“. Archivovány od originál dne 3. dubna 2007. Citováno 16. dubna 2007. Citovat deník vyžaduje | deník = (Pomoc)
  4. ^ H. Parmar, M. Thornburgh (eds.) Real Messaging Protocol společnosti Adobe, Adobe, 21. prosince 2012
  5. ^ „Specifikace protokolu RTMP (Real-Time Messaging Protocol)“. Citováno 8. května 2014.
  6. ^ Licence RTMP Specification, Publikováno v dubnu 2009
  7. ^ Schumacher-Rasmussen, Eric (27. května 2011). „Wowza popírá tvrzení společnosti Adobe o porušení patentů“. streamingmedia.com.
  8. ^ Lawler, Ryan (31. května 2011). „Wowza vystřelí zpět na Adobe ve Flash Patent Suit“. gigaom.com.
  9. ^ „ADOBE SYSTEMS INCORPORATE - č. C 11-2243 CW. - 20120907565 - Leagle.com“. leagle.com.
  10. ^ Wowza Media Systems a Adobe Systems urovnávají případy patentů http://www.wowza.com/news/wowza-media-systems-and-adobe-systems-settle-patent-cases
  11. ^ Projekt Red5 (2009) Ping. Dostupný z: http://trac.red5.org/wiki/Documentation/Tutorials/Ping. Přístup k: 25. prosince 2011
  12. ^ „Aktualizace: 11. 11. 2009“. Citováno 1. listopadu 2009.

externí odkazy