網(wǎng)絡(luò)流媒體協(xié)議之——RTSP協(xié)議

RTSP(Real-Time Stream Protocol)協(xié)議是一個基于文本的多媒體播放控制協(xié)議嘉抓,屬于應(yīng)用層毡泻。RTSP以客戶端方式工作,對流媒體提供播放媳瞪、暫停骗炉、后退、前進等操作蛇受。該標(biāo)準(zhǔn)由IETF指定句葵,對應(yīng)的協(xié)議是RFC2326。

RTSP作為一個應(yīng)用層協(xié)議兢仰,提供了一個可供擴展的框架乍丈,使得流媒體的受控和點播變得可能,它主要用來控制具有實時特性的數(shù)據(jù)的發(fā)送把将,但其本身并不用于傳送流媒體數(shù)據(jù)轻专,而必須依賴下層傳輸協(xié)議(如RTP/RTCP)所提供的服務(wù)來完成流媒體數(shù)據(jù)的傳送。RTSP負(fù)責(zé)定義具體的控制信息察蹲、操作方法铭若、狀態(tài)碼,以及描述與RTP之間的交互操作递览。RTSP媒體服務(wù)協(xié)議框架如下:

RTSP包含Normal RTSP(數(shù)據(jù)通過RTP傳輸,應(yīng)用廠商有蘋果和微軟等)瞳腌,以及Real-RTSP(數(shù)據(jù)通過RDT傳輸)绞铃。本篇我們主要講Normal RTSP。

RTSP傳輸?shù)囊话闶荰S嫂侍、MP4格式的流儿捧,其傳輸一般需要2~3個通道,命令和數(shù)據(jù)通道分離挑宠。使用RTSP協(xié)議傳輸流媒體數(shù)據(jù)需要有專門的媒體播放器和媒體服務(wù)器菲盾,也就是需要支持RTSP協(xié)議的客戶端和服務(wù)器。

客戶端要播放RTSP媒體流各淀,就需要知道媒體源的URL懒鉴,RTSP的URL格式一般如下:

rtsp://host[:port]/[abs_path]/content_name

host: 有效的域名或IP地址;

port: 端口號,缺省為554临谱,若為缺省可不填寫璃俗,否則必須寫明。

例如悉默,一個完整的RTSP URL可寫為:

rtsp://192.168.1.67:554/test

又如目前市面上常用的撼腔恚康網(wǎng)絡(luò)攝像頭的RTSP地址格式為:

rtsp://[username]:[password]@[ip]:[port]/[codec]/[channel]/[subtype]/av_stream

示例: rtsp://admin:12345@192.168.1.67:554/h264/ch1/main/av_stream

rtsp://admin:12345@192.168.1.67/mpeg4/ch1/sub/av_stream

RTSP報文

對RTSP協(xié)議的使用有了一個大概的了解之后,我們來看一下RTSP報文結(jié)構(gòu)抄课。

RTSP是一種基于文本的協(xié)議唱星,用CRLF(回車換行)作為每一行的結(jié)束符,其好處是跟磨,在使用過程中可以方便地增加自定義參數(shù)间聊,也方便抓包分析。從消息傳送方向上來分吱晒,RTSP的報文有兩類:請求報文和響應(yīng)報文脯宿。請求報文是指從客戶端向服務(wù)器發(fā)送的請求(也有少量從服務(wù)器向客戶端發(fā)送的請求)鹃答,響應(yīng)報文是指從服務(wù)器到客戶端的回應(yīng)。

RTSP請求報文的常用方法與作用:

一次基本的RTSP交互過程如下,C表示客戶端彬犯,S表示服務(wù)端。

首先客戶端連接到流媒體服務(wù)器并發(fā)送一個RTSP描述請求(DESCRIBE request)售滤,服務(wù)器通過一個SDP(Session DescriptionProtocol)描述來進行反饋(DESCRIBEresponse)收苏,反饋信息包括流數(shù)量、媒體類型等信息喉酌∪劝迹客戶端分析該SDP描述,并為會話中的每一個流發(fā)送一個RTSP連接建立請求(SETUPrequest)泪电,該命令會告訴服務(wù)器用于接收媒體數(shù)據(jù)的端口般妙,服務(wù)器響應(yīng)該請求(SETUP response)并建立連接之后,就開始傳送媒體流(RTP包)到客戶端相速。在播放過程中客戶端還可以向服務(wù)器發(fā)送請求來控制快進碟渺、快退和暫停等。最后突诬,客戶端可發(fā)送一個終止請求(TEARDOWN request)來結(jié)束流媒體會話苫拍。

下面我們通過具體的消息實例來進一步了解一下RTSP的工作過程:

OPTIONS

OPTIONS請求是客戶端向服務(wù)器詢問可用的方法,請求和回復(fù)實例如下:

C->S: OPTIONS rtsp://example.com/media.mp4 RTSP/1.0

CSeq: 1

Require: implicit-play

Proxy-Require: gzipped-messages

S->C: RTSP/1.0 200 OK

CSeq: 1

Public: DESCRIBE, SETUP, TEARDOWN, PLAY, PAUSE

DESCRIBE

客戶端向服務(wù)器請求媒體資源描述旺隙,服務(wù)器端通過SDP(Session Description Protocol)格式回應(yīng)客戶端的請求绒极。資源描述中會列出所請求媒體的媒體流及其相關(guān)信息,典型情況下蔬捷,音頻和視頻分別作為一個媒體流傳輸垄提。實例如下:

C->S: DESCRIBE rtsp://example.com/media.mp4 RTSP/1.0

CSeq: 2

S->C: RTSP/1.0 200 OK

CSeq: 2

Content-Base: rtsp://example.com/media.mp4

Content-Type: application/sdp

Content-Length: 460

m=video 0 RTP/AVP 96

a=control:streamid=0

a=range:npt=0-7.741000

a=length:npt=7.741000

a=rtpmap:96 MP4V-ES/5544

a=mimetype:string;"video/MP4V-ES"

a=AvgBitRate:integer;304018

a=StreamName:string;"hinted video track"

m=audio 0 RTP/AVP 97

a=control:streamid=1

a=range:npt=0-7.712000

a=length:npt=7.712000

a=rtpmap:97 mpeg4-generic/32000/2

a=mimetype:string;"audio/mpeg4-generic"

a=AvgBitRate:integer;65790

a=StreamName:string;"hinted audio track"

SETUP

SETUP請求確定了具體的媒體流如何傳輸,該請求必須在PLAY請求之前發(fā)送。SETUP請求包含媒體流的URL和客戶端用于接收RTP數(shù)據(jù)(audio or video)的端口以及接收RTCP數(shù)據(jù)(meta information)的端口塔淤。服務(wù)器端的回復(fù)通常包含客戶端請求參數(shù)的確認(rèn)摘昌,并會補充缺失的部分,比如服務(wù)器選擇的發(fā)送端口高蜂。每一個媒體流在發(fā)送PLAY請求之前聪黎,都要首先通過SETUP請求來進行相應(yīng)的配置。

C->S: SETUP rtsp://example.com/media.mp4/streamid=0 RTSP/1.0

CSeq: 3

Transport: RTP/AVP;unicast;client_port=8000-8001

S->C: RTSP/1.0 200 OK

CSeq: 3

Transport: RTP/AVP;unicast;client_port=8000-8001;server_port=9000-9001;ssrc=1234ABCD

Session: 12345678

PLAY

客戶端通過PLAY請求來播放一個或全部媒體流备恤,PLAY請求可以發(fā)送一次或多次稿饰,發(fā)送一次時,URL為包含所有媒體流的地址露泊,發(fā)送多次時喉镰,每一次請求攜帶的URL只包含一個相應(yīng)的媒體流。PLAY請求中可指定播放的range惭笑,若未指定侣姆,則從媒體流的開始播放到結(jié)束,如果媒體流在播放過程中被暫停沉噩,則可在暫停處重新啟動流的播放捺宗。

C->S: PLAY rtsp://example.com/media.mp4 RTSP/1.0

CSeq: 4

Range: npt=5-20

Session: 12345678

S->C: RTSP/1.0 200 OK

CSeq: 4

Session: 12345678

RTP-Info: url=rtsp://example.com/media.mp4/streamid=0;seq=9810092;rtptime=3450012

PAUSE

PAUSE請求會暫停一個或所有媒體流,后續(xù)可通過PLAY請求恢復(fù)播放川蒙。PAUSE請求中攜帶所請求媒體流的URL蚜厉,若參數(shù)range存在,則指明在何處暫停畜眨,若該參數(shù)不存在昼牛,則暫停立即生效,且暫停時長不確定康聂。

C->S: PAUSE rtsp://example.com/media.mp4 RTSP/1.0

CSeq: 5

Session: 12345678

S->C: RTSP/1.0 200 OK

CSeq: 5

Session: 12345678

TEARDOWN

結(jié)束會話請求贰健,該請求會停止所有媒體流,并釋放服務(wù)器上的相關(guān)會話數(shù)據(jù)恬汁。

C->S: TEARDOWN rtsp://example.com/media.mp4 RTSP/1.0

CSeq: 8

Session: 12345678

S->C: RTSP/1.0 200 OK

CSeq: 8

GET_PARAMETER

檢索指定URI數(shù)據(jù)中的參數(shù)值伶椿。不攜帶消息體的GET_PARAMETER可用來測試服務(wù)器端或客戶端是否可通(類似ping的功能)。

S->C: GET_PARAMETER rtsp://example.com/media.mp4 RTSP/1.0

CSeq: 9

Content-Type: text/parameters

Session: 12345678

Content-Length: 15

packets_received

jitter

C->S: RTSP/1.0 200 OK

CSeq: 9

Content-Length: 46

Content-Type: text/parameters

packets_received: 10

jitter: 0.3838

SET_PARAMETER

用于設(shè)置指定媒體流的參數(shù)蕊连。

C->S: SET_PARAMETER rtsp://example.com/media.mp4 RTSP/1.0

CSeq: 10

Content-length: 20

Content-type: text/parameters

barparam: barstuff

S->C: RTSP/1.0 451 Invalid Parameter

CSeq: 10

Content-length: 10

Content-type: text/parameters

barparam

REDIRECT

重定向請求,用于服務(wù)器通知客戶端新的服務(wù)地址游昼,客戶端需要向這個新地址重新發(fā)起請求甘苍。重定向請求中可能包含Range參數(shù),指明重定向生效的時間烘豌≡赝ィ客戶端若需向新服務(wù)地址發(fā)起請求,必須先teardown當(dāng)前會話,再向指定的新主機setup一個新的會話囚聚。

S->C: REDIRECT rtsp://example.com/media.mp4 RTSP/1.0

CSeq: 11

Location: rtsp://bigserver.com:8001

Range: clock=19960213T143205Z-

ANNOUNCE

ANNOUNCE請求有兩個用途:(1)C->S:客戶端向服務(wù)器端發(fā)布URL指定的媒體信息描述靖榕;(2) S->C:實時更新對話描述。若媒體表示中新增了一個媒體流顽铸,例如在直播過程中茁计,則整個媒體表示的description都要被重新發(fā)送,而不是只發(fā)送新增部分谓松。

C->S: ANNOUNCE rtsp://example.com/media.mp4 RTSP/1.0

CSeq: 7

Date: 23 Jan 1997 15:35:06 GMT

Session: 12345678

Content-Type: application/sdp

Content-Length: 332

v=0

o=mhandley 2890844526 2890845468 IN IP4 126.16.64.4

s=SDP Seminar

i=A Seminar on the session description protocol

u=http://www.cs.ucl.ac.uk/staff/M.Handley/sdp.03.ps

e=mjh@isi.edu (Mark Handley)

c=IN IP4 224.2.17.12/127

t=2873397496 2873404696

a=recvonly

m=audio 3456 RTP/AVP 0

m=video 2232 RTP/AVP 31

S->C: RTSP/1.0 200 OK

CSeq: 7

RECORD

請求錄制指定范圍的媒體數(shù)據(jù)星压,請求中可指定錄制的起止時間戳;若未指定時間范圍鬼譬,則使用presentation description中的開始和結(jié)束時間娜膘,這種情況下,如果會話已開始优质,則立即啟動錄制操作竣贪。

C->S: RECORD rtsp://example.com/media.mp4 RTSP/1.0

CSeq: 6

Session: 12345678

S->C: RTSP/1.0 200 OK

CSeq: 6

Session: 12345678

以上就是RTSP中常用的命令及其實例介紹。最后巩螃,來看一段實際使用的RTSP命令交互過程演怎,該過程是通過PC對海康攝像頭視頻流的拉取和播放牺六,并通過Wireshark抓取客戶端的數(shù)據(jù)得到的:

OPTIONS rtsp://10.3.8.202:554 RTSP/1.0

CSeq: 2

User-Agent: LibVLC/2.2.8 (LIVE555 Streaming Media v2016.02.22)

RTSP/1.0 200 OK

CSeq: 2

Public: OPTIONS, DESCRIBE, PLAY, PAUSE, SETUP, TEARDOWN, SET_PARAMETER, GET_PARAMETER

Date: Mon, Jan 29 2018 16:56:47 GMT

DESCRIBE rtsp://10.3.8.202:554 RTSP/1.0

CSeq: 3

User-Agent: LibVLC/2.2.8 (LIVE555 Streaming Media v2016.02.22)

Accept: application/sdp

RTSP/1.0 401 Unauthorized

CSeq: 3

WWW-Authenticate: Digest realm="IP Camera(10789)", nonce="6b9a455aec675b8db81a9ceb802e4eb8", stale="FALSE"

Date: Mon, Jan 29 2018 16:56:47 GMT

DESCRIBE rtsp://10.3.8.202:554 RTSP/1.0

CSeq: 4

Authorization: Digest username="admin", realm="IP Camera(10789)", nonce="6b9a455aec675b8db81a9ceb802e4eb8", uri="rtsp://10.3.8.202:554", response="3fc4b15d7a923fc36f32897e3cee69aa"

User-Agent: LibVLC/2.2.8 (LIVE555 Streaming Media v2016.02.22)

Accept: application/sdp

RTSP/1.0 200 OK

CSeq: 4

Content-Type: application/sdp

Content-Base: rtsp://10.3.8.202:554/

Content-Length: 551

v=0

o=- 1517245007527432 1517245007527432 IN IP4 10.3.8.202

s=Media Presentation

e=NONE

b=AS:5050

t=0 0

a=control:rtsp://10.3.8.202:554/

m=video 0 RTP/AVP 96

c=IN IP4 0.0.0.0

b=AS:5000

a=recvonly

a=x-dimensions:2048,1536

a=control:rtsp://10.3.8.202:554/trackID=1

a=rtpmap:96 H264/90000

a=fmtp:96 profile-level-id=420029; packetization-mode=1; sprop-parameter-sets=Z00AMp2oCAAwabgICAoAAAMAAgAAAwBlCA==,aO48gA==

a=Media_header:MEDIAINFO=494D4B48010200000400000100000000000000000000000000000000000000000000000000000000;

a=appversion:1.0

SETUP rtsp://10.3.8.202:554/trackID=1 RTSP/1.0

CSeq: 5

Authorization: Digest username="admin", realm="IP Camera(10789)", nonce="6b9a455aec675b8db81a9ceb802e4eb8", uri="rtsp://10.3.8.202:554/", response="ddfbf3e268ae954979407369a104a620"

User-Agent: LibVLC/2.2.8 (LIVE555 Streaming Media v2016.02.22)

Transport: RTP/AVP;unicast;client_port=57844-57845

RTSP/1.0 200 OK

CSeq: 5

Session: 1273222592;timeout=60

Transport: RTP/AVP;unicast;client_port=57844-57845;server_port=8218-8219;ssrc=5181c73a;mode="play"

Date: Mon, Jan 29 2018 16:56:47 GMT

PLAY rtsp://10.3.8.202:554/ RTSP/1.0

CSeq: 6

Authorization: Digest username="admin", realm="IP Camera(10789)", nonce="6b9a455aec675b8db81a9ceb802e4eb8", uri="rtsp://10.3.8.202:554/", response="b5abf0b230de4b49d6c6d42569f88e91"

User-Agent: LibVLC/2.2.8 (LIVE555 Streaming Media v2016.02.22)

Session: 1273222592

Range: npt=0.000-

RTSP/1.0 200 OK

CSeq: 6

Session: 1273222592

RTP-Info: url=rtsp://10.3.8.202:554/trackID=1;seq=65373;rtptime=3566398668

Date: Mon, Jan 29 2018 16:56:47 GMT

GET_PARAMETER rtsp://10.3.8.202:554/ RTSP/1.0

CSeq: 7

Authorization: Digest username="admin", realm="IP Camera(10789)", nonce="6b9a455aec675b8db81a9ceb802e4eb8", uri="rtsp://10.3.8.202:554/", response="bb2309dcd083b25991c13e165673687b"

User-Agent: LibVLC/2.2.8 (LIVE555 Streaming Media v2016.02.22)

Session: 1273222592

RTSP/1.0 200 OK

CSeq: 7

Date: Mon, Jan 29 2018 16:56:47 GMT

TEARDOWN rtsp://10.3.8.202:554/ RTSP/1.0

CSeq: 8

Authorization: Digest username="admin", realm="IP Camera(10789)", nonce="6b9a455aec675b8db81a9ceb802e4eb8", uri="rtsp://10.3.8.202:554/", response="e08a15c27d3daac14fd4b4bcab424a5e"

User-Agent: LibVLC/2.2.8 (LIVE555 Streaming Media v2016.02.22)

Session: 1273222592

RTSP/1.0 200 OK

CSeq: 8

Session: 1273222592

Date: Mon, Jan 29 2018 16:57:03 GMT

今天的內(nèi)容就分享到這里颤枪,需要音視頻相關(guān)學(xué)習(xí)資料的可以加q裙812855908,免費分享

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末淑际,一起剝皮案震驚了整個濱河市畏纲,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌春缕,老刑警劉巖盗胀,帶你破解...
    沈念sama閱讀 212,029評論 6 492
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異锄贼,居然都是意外死亡票灰,警方通過查閱死者的電腦和手機,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,395評論 3 385
  • 文/潘曉璐 我一進店門宅荤,熙熙樓的掌柜王于貴愁眉苦臉地迎上來屑迂,“玉大人,你說我怎么就攤上這事冯键∪桥危” “怎么了?”我有些...
    開封第一講書人閱讀 157,570評論 0 348
  • 文/不壞的土叔 我叫張陵惫确,是天一觀的道長手报。 經(jīng)常有香客問我蚯舱,道長,這世上最難降的妖魔是什么掩蛤? 我笑而不...
    開封第一講書人閱讀 56,535評論 1 284
  • 正文 為了忘掉前任枉昏,我火速辦了婚禮,結(jié)果婚禮上揍鸟,老公的妹妹穿的比我還像新娘兄裂。我一直安慰自己,他們只是感情好蜈亩,可當(dāng)我...
    茶點故事閱讀 65,650評論 6 386
  • 文/花漫 我一把揭開白布懦窘。 她就那樣靜靜地躺著,像睡著了一般稚配。 火紅的嫁衣襯著肌膚如雪畅涂。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 49,850評論 1 290
  • 那天道川,我揣著相機與錄音午衰,去河邊找鬼。 笑死冒萄,一個胖子當(dāng)著我的面吹牛臊岸,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播尊流,決...
    沈念sama閱讀 39,006評論 3 408
  • 文/蒼蘭香墨 我猛地睜開眼帅戒,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了崖技?” 一聲冷哼從身側(cè)響起逻住,我...
    開封第一講書人閱讀 37,747評論 0 268
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎迎献,沒想到半個月后瞎访,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 44,207評論 1 303
  • 正文 獨居荒郊野嶺守林人離奇死亡吁恍,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 36,536評論 2 327
  • 正文 我和宋清朗相戀三年扒秸,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片冀瓦。...
    茶點故事閱讀 38,683評論 1 341
  • 序言:一個原本活蹦亂跳的男人離奇死亡伴奥,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出翼闽,到底是詐尸還是另有隱情拾徙,我是刑警寧澤,帶...
    沈念sama閱讀 34,342評論 4 330
  • 正文 年R本政府宣布肄程,位于F島的核電站锣吼,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏蓝厌。R本人自食惡果不足惜玄叠,卻給世界環(huán)境...
    茶點故事閱讀 39,964評論 3 315
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望拓提。 院中可真熱鬧读恃,春花似錦、人聲如沸代态。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,772評論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽蹦疑。三九已至西雀,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間歉摧,已是汗流浹背艇肴。 一陣腳步聲響...
    開封第一講書人閱讀 32,004評論 1 266
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留叁温,地道東北人再悼。 一個月前我還...
    沈念sama閱讀 46,401評論 2 360
  • 正文 我出身青樓,卻偏偏與公主長得像膝但,于是被迫代替她去往敵國和親冲九。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 43,566評論 2 349

推薦閱讀更多精彩內(nèi)容