定義:
RTSP[3]協議以客戶服務器方式工作,它是一個多媒體播放控制協議,用來使用戶在播放從因特網下載的實時數據時能夠進行控制,如:暫停/繼續、後退、前進等。因此 RTSP 又稱爲“因特網錄像機遙控協議”。
客戶端和服務端rtsp實現過程:
1.客戶端發起RTSP OPTION請求,目的是得到服務器提供的方法。RTSP提供的方法一般包括OPTIONS、DESCRIBE、SETUP、TEARDOWN、PlAY、PAUSE、SCALE、GET_PARAMETER。
2.服務器對RTSP OPTION迴應,服務器提供什麼方法就回復什麼方法。下面,我們只對DESCRIBE、SETUP、TEARDOWN、PLAY、PAUSE方法做了具體解釋。
3.客戶端發起RTSP DESCRIBE請求,服務器收到的信息主要有媒體的名字,解碼類型,視頻分辨率等描述,目的是爲了從服務器那裏得到會話描述信息。
4.客戶端對RTSP DESCRIBE響應,發送必要的媒體參數,在傳輸H.264文件時,主要包括SPS/PPS、媒體名、傳輸協議等信息。
5.客戶端發起RTSP SETUP請求,目的是請求會話建立並準備傳輸。請求信息主要包括傳輸協議和客戶端端口號。
6.服務器對RTSP SETUP響應,目的是請求播放視頻流。
7.客戶端發出了RTSP PLAY請求,目的是請求播放視頻流。
8.服務器對RTSP PLAY響應,響應的信息包括會話標識符,RTP包的序列號,時間戳。此時服務器對H264視頻流封裝打包進行傳輸。
9.客戶端發出RTSP TEARDOWN請求,目的是關閉連接,終止傳輸。
10.服務器關閉連接,停止傳輸。
模擬過程:
客戶端->>服務器:OPTION
服務器->>客戶端: DESCRIBE, SETUP, TEARDOWN, PLAY,PAUSE,OPTIONS等
客戶端->>服務器:DESCRIBE
服務器->>客戶端:200 OK (SDP)
客戶端->>服務器:PLAY
服務器->>客戶端: (RTP包)
RTSP協議與HTTP協議的區別:
1.RTSP引入了幾種新的方法,比如DESCRIBE、PLAY、SETUP等,並且有不同的協議標識符,RTSP爲rtsp1.0,HTTP爲http1.1;
2.HTTP是無狀態的協議,而RTSP爲每個會話保持狀態;
3.RTSP協議的客戶端和服務器端都可以發送Request請求,而在HTTPF協議中,只有客戶端能發送Request請求。
4.在RTSP協議中,載荷數據一般是通過帶外方式來傳送的(除了交織的情況),及通過RTP協議在不同的通道中來傳送載荷數據。而HTTP協議的
載荷數據都是通過帶內方式傳送,比如請求的網頁數據是在迴應的消息體中攜帶的。
5.使用ISO 10646(UTF-8)而不是ISO 8859-1,以配合當前HTML的國際化。
6.RTSP使用URL請求時包含絕對URL、而由於歷史原因造成的向後兼容性問題,HTTP/1.1只在請求中包含絕對路徑,把主機名放入單獨的標題域中。
RTSP的方法:
rtsp中定義的方法有:OPTIONS, DESCRIBE, SETUP, TEARDOWN, PLAY, PAUSE, SCALE, GET_PARAMETER ,SET_PARAMETER ,下面就說常用的:
1.OPTION —目的是得到服務器提供的可用方法:
客服端發送的格式:
OPTIONS rtsp://192.168.20.136:5000/xxx666 RTSP/1.0
CSeq: 1 //每個消息都有序號來標記,第一個包通常是option請求消息
User-Agent: VLC media player (LIVE555 Streaming Media v2005.11.10)
服務器的迴應信息包括提供的一些方法,例如:
RTSP/1.0 200 OK
Server: UServer 0.9.7_rc1
Cseq: 1 //每個迴應消息的cseq數值和請求消息的cseq相對應
Public: OPTIONS, DESCRIBE, SETUP, TEARDOWN, PLAY, PAUSE, SCALE, GET_PARAMETER //服務器提供的可用的方法
2.DESCRIBE —C向S發起DESCRIBE請求,爲了得到會話描述信息(SDP):
客服端發送的格式:
DESCRIBE rtsp://192.168.20.136:5000/xxx666 RTSP/1.0
CSeq: 2
token:
Accept: application/sdp
User-Agent: VLC media player (LIVE555 Streaming Media v2005.11.10)
服務器迴應一些對此會話的描述信息(sdp):
RTSP/1.0 200 OK
Server: UServer 0.9.7_rc1
Cseq: 2
x-prev-url: rtsp://192.168.20.136:5000
x-next-url: rtsp://192.168.20.136:5000
x-Accept-Retransmit: our-retransmit
x-Accept-Dynamic-Rate: 1
Cache-Control: must-revalidate
Last-Modified: Fri, 10 Nov 2006 12:34:38 GMT
Date: Fri, 10 Nov 2006 12:34:38 GMT
Expires: Fri, 10 Nov 2006 12:34:38 GMT
Content-Base: rtsp://192.168.20.136:5000/xxx666/
Content-Length: 344
Content-Type: application/sdp
v=0 //以下都是sdp信息
o=OnewaveUServerNG 1451516402 1025358037 IN IP4 192.168.20.136
s=/xxx666
u=http:///
e=admin@
c=IN IP4 0.0.0.0
t=0 0
a=isma-compliance:1,1.0,1
a=range:npt=0-
m=video 0 RTP/AVP 96 //m表示媒體描述,下面是對會話中視頻通道的媒體描述
a=rtpmap:96 MP4V-ES/90000
a=fmtp:96 profile-level-id=245;config=000001B0F5000001B509000001000000012000C888B0E0E0FA62D089028307
a=control:trackID=0//trackID=0表示視頻流用的是通道0
3.SETUP —客戶端提醒服務器建立會話,並確定傳輸模式:
客服端發送的格式:
SETUP rtsp://192.168.20.136:5000/xxx666/trackID=0 RTSP/1.0
CSeq: 3
Transport: RTP/AVP/TCP;unicast;interleaved=0-1
User-Agent: VLC media player (LIVE555 Streaming Media v2005.11.10)
//uri中帶有trackID=0,表示對該通道進行設置。Transport參數設置了傳輸模式,包的結構。接下來的數據包頭部第二個字節位置就是interleaved,它的值是每個通道都不同的,trackID=0的interleaved值有兩個0或1,0表示rtp包,1表示rtcp包,接受端根據interleaved的值來區別是哪種數據包。
服務器迴應信息:
RTSP/1.0 200 OK
Server: UServer 0.9.7_rc1
Cseq: 3
Session: 6310936469860791894 //服務器迴應的會話標識符
Cache-Control: no-cache
Transport: RTP/AVP/TCP;unicast;interleaved=0-1;ssrc=6B8B4567
4.PLAY —客戶端發送播放請求:
客服端發送的格式:
PLAY rtsp://192.168.20.136:5000/xxx666 RTSP/1.0
CSeq: 4
Session: 6310936469860791894
Range: npt=0.000- //設置播放時間的範圍
User-Agent: VLC media player (LIVE555 Streaming Media v2005.11.10)
服務器迴應信息:
RTSP/1.0 200 OK
Server: UServer 0.9.7_rc1
Cseq: 4
Session: 6310936469860791894
Range: npt=0.000000-
RTP-Info: url=trackID=0;seq=17040;rtptime=1467265309
//seq和rtptime都是rtp包中的信息
5.TEARDOWN ---客戶端發起關閉請求:
客服端發送的格式:
TEARDOWN rtsp://192.168.20.136:5000/xxx666 RTSP/1.0
CSeq: 5
Session: 6310936469860791894
User-Agent: VLC media player (LIVE555 Streaming Media v2005.11.10)
服務器迴應:
RTSP/1.0 200 OK
Server: UServer 0.9.7_rc1
Cseq: 5
Session: 6310936469860791894
Connection: Close
以上方法都是交互過程中最爲常用的,其它還有一些重要的方法如get/set_parameter,pause,redirect等等
ps:
sdp的格式
v=<version>
o=<username> <session id> <version> <network type> <address type> <address>
s=<session name>
i=<session description>
u=<URI>
e=<email address>
p=<phone number>
c=<network type> <address type> <connection address>
b=<modifier>:<bandwidth-value>
t=<start time> <stop time>
r=<repeat interval> <active duration> <list of offsets from start-time>
z=<adjustment time> <offset> <adjustment time> <offset> ....
k=<method>
k=<method>:<encryption key>
a=<attribute>
a=<attribute>:<value>
m=<media> <port> <transport> <fmt list>
v = (協議版本)
o = (所有者/創建者和會話標識符)
s = (會話名稱)
i = * (會話信息)
u = * (URI 描述)
e = * (Email 地址)
p = * (電話號碼)
c = * (連接信息)
b = * (帶寬信息)
z = * (時間區域調整)
k = * (加密密鑰)
a = * (0 個或多個會話屬性行)
時間描述:
t = (會話活動時間)
r = * (0或多次重複次數)
媒體描述:
m = (媒體名稱和傳輸地址)
i = * (媒體標題)
c = * (連接信息 — 如果包含在會話層則該字段可選)
b = * (帶寬信息)
k = * (加密密鑰)
a = * (0 個或多個媒體屬性行)