• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>

            elva

            RTSP協議

            因為項目需要,學習了一下RTSP協議,為了防止以后忘記,就把學習過程和成果記載下來。期間參考了一些網上的資料,并分析了VLC的RTSP報文。
                RTSP(Real Time Streaming Protocol,實時流協議),是由Real Network和Netscape共同提出的如何有效地在IP網絡上傳輸流媒體數據的應用層協議。RTSP提供一種可擴展的框架,能夠提供可控制的,按需 傳輸的實時數據,比如音頻和視頻文件。源數據可以包括現場數據的反饋和存儲的文件。RTSP對流媒體提供了諸如暫停,快進等控制,而它本身并不傳輸數 據,RTSP的作用相當于流媒體服務器的遠程控制。傳輸數據可以通過傳輸層的TCP/UDP協議,RTSP也提供了基于RTP傳輸機制的一些有效的方法。
            RTSP消息格式:
            RTSP的消息有兩大類,一是請求消息(request),一是回應消息(response),兩種消息的格式不同。
            請求消息:
                   方法 URI RTSP版本 CR LF
                   消息頭 CR LF CR LF        
                   消息體 CR LF
               其中方法包括OPTIONS回應中所有的命令,URI是接收方(服務端)的地址,例如:rtsp://192.168.22.136:5000/v0
            RTSP版本一般都是RTSP/1.0。每行后面的CR LF表示回車換行,需要接收端有相應的解析,最后一個消息頭需要有兩個CR LF
            回應消息:
                   RTSP版本 狀態碼 解釋 CR LF
                   消息頭 CR LF CR LF
                   消息體 CR LF
                其中RTSP版本一般都是RTSP/1.0,狀態碼是一個數值,200表示成功,解釋是與狀態碼對應的文本解釋。
            簡單的RTSP交互過程:
            C表示RTSP客戶端,S表示RTSP服務端
            1.C->S:OPTIONS request    //詢問S有哪些方法可用
            1.S->C:OPTIONS response   //S回應信息中包括提供的所有可用方法

            2.C->S:DESCRIBE request   //要求得到S提供的媒體初始化描述信息
            2.S->C:DESCRIBE response  //S回應媒體初始化描述信息,主要是sdp
             
            3.C->S:SETUP request      //設置會話的屬性,以及傳輸模式,提醒S建立會話
            3.S->C:SETUP response     //S建立會話,返回會話標識符,以及會話相關信息
             
            4.C->S:PLAY request       //C請求播放
            4.S->C:PLAY response      //S回應該請求的信息
             
            S->C:發送流媒體數據
            5.C->S:TEARDOWN request   //C請求關閉會話
            5.S->C:TEARDOWN response  //S回應該請求
             
                上述的過程是標準的、友好的rtsp流程,但實際的需求中并不一定按部就班來。其中第3和4步是必需的!第一步,只要服務器客戶端約定好,有哪些方法可 用,則OPTIONS請求可以不要。第二步,如果我們有其他途徑得到媒體初始化描述信息(比如http請求等等),則我們也不需要通過RTSP中的 DESCRIBE請求來完成。第五步,可以根據系統需求的設計來決定是否需要。
            rtsp中常用方法:
            1.OPTIONS
            目的是得到服務器提供的可用方法:
            OPTIONS rtsp://192.168.22.136:5000/v0 RTSP/1.0
            CSeq: 1 //每個消息都有序號來標記,第一個包通常是OPTIONS請求消息
            User-Agent: bestilyq //自定義的字符串
             
            服務器的回應信息包括提供的一些方法。例如:
            RTSP/1.0 200 OK
            Cseq: 1         //每個回應消息的cseq數值和請求消息的cseq相對應
            Public: OPTIONS, DESCRIBE, SETUP, TEARDOWN, PLAY //服務器提供的可用的方法

            2.DESCRIBE
            C向S發起DESCRIBE請求,為了得到會話描述信息(SDP):
            DESCRIBE rtsp://192.168.20.136:5000/v0 RTSP/1.0
            CSeq: 2
            Accept: application/sdp
            Authorization: Basic YWRtaW46YWRtaW4= //有認證,不需要認證時不需要該字段
            User-Agent: bestilyq
             
            服務器回應一些對此會話的描述信息(sdp):
            RTSP/1.0 200 OK
            Cseq: 2
            Date: Sat Feb  5 22:49:39 2009 GMT
            Content-Type: application/sdp
            Content-Length: 182
             
            v=0                     //以下都是sdp信息
            o=- 0 0 IN IPV4 127.0.0.1
            t=0 0
            s=No Name
            a=tool:libavformat
            m=video 0 RTP/AVP 96 //m表示媒體描述,下面是對會話中視頻通道的媒體描述
            b=AS:2000
            a=rtpmap:96 MP4V-ES/90000
            a=fmtp:96 profile-level-id=1
            a=control:streamid=0 //streamid=0表示視頻流用的是通道0

            3.SETUP
            客戶端提醒服務器建立會話,并確定傳輸模式:
            (1)TCP模式
            SETUP rtsp://192.168.20.136:5000/v0/streamid=0 RTSP/1.0   
            CSeq: 3
            Authorization: Basic YWRtaW46YWRtaW4=
            Transport: RTP/AVP/TCP;unicast;interleaved=0-1     
            User-Agent: bestilyq
            (2)UDP模式
            SETUP rtsp://192.168.20.136:5000/v0/streamid=0
            RTSP/1.0
            CSeq: 3
            Transport: RTP/AVP;unicast;client_port=3008-3009
            Authorization: Basic YWRtaW46YWRtaW4=
            User-Agent: bestilyq
                URI中帶有streamid=0,表示對該通道進行設置。
                Transport參數設置了傳輸模式。
            RTP/AVP/TCP表示通過TCP傳輸RTP包,RTP/AVP表示使用UDP傳輸RTP包。unicast表示單播。interleaved 值有兩個:0和1,0表示RTP包,1表示RTCP包,接收端根據interleaved的值來區別是哪種數據包。client_port值有3008和 3009,3008表示客戶端接收RTP包的端口,3009表示客戶端接收RTCP包的端口,服務端要分別將RTP包和RTCP包發送到這兩個端口。
             
            服務器回應信息:
            (1)TCP模式
            RTSP/1.0 200 OK
            CSeq: 3
            Date: Sat Feb  5 22:35:27 2009 GMT
            Session: a522bbb4335617db
            Transport: RTP/AVP/TCP;interleaved=0-1
            (2)UDP模式
            RTSP/1.0 200 OK
            CSeq: 3
            Date: Sat Feb  5 22:49:39 2009 GMT
            Session: 01fa4ca2566a6301      //服務器回應的會話標識符
            Transport: RTP/AVP/UDP;unicast;client_port=3008-3009;server_port=1024-1025

            4.PLAY
            客戶端發送播放請求:
            PLAY rtsp://192.168.20.136:5000/v0 RTSP/1.0
            CSeq: 4
            Session: a522bbb4335617db      //SETUP返回的會話標識符
            Range: npt=0.000-              //設置播放時間的范圍
            User-Agent: bestilyq

            服務器回應信息:
            RTSP/1.0 200 OK
            CSeq: 4
            Date: Sat Feb  5 22:49:39 2009 GMT
            Session: a522bbb4335617db

            5.TEARDOWN
            客戶端發起關閉請求:
            TEARDOWN rtsp://192.168.20.136:5000/v0 RTSP/1.0
            CSeq: 5
            Session: a522bbb4335617db
            User-Agent: bestilyq

            服務器回應:
            RTSP/1.0 200 OK
            Cseq: 5
            Date: Sat Feb  5 22:49:47 2009 GMT
            Session: a522bbb4335617db

                以上方法都是交互過程中最為常用的,其它還有一些重要的方法如GET_PARAMETER,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 個或多個媒體屬性行)
            帶*為可選信息。

            參考文章:rfc2326(rtsp);rfc2327(sdp) ;rfc
            3550(rtp/rtcp)

            原帖地址:
            http://blog.chinaunix.net/u2/77292/showart_1922940.html

            posted on 2010-08-13 11:45 葉子 閱讀(11468) 評論(0)  編輯 收藏 引用 所屬分類: MPEG

            久久九九青青国产精品| 日韩人妻无码一区二区三区久久99 | 97久久婷婷五月综合色d啪蜜芽| 欧美午夜A∨大片久久| 丁香色欲久久久久久综合网| 国产∨亚洲V天堂无码久久久| 99久久国产综合精品成人影院| 久久性生大片免费观看性| 人妻精品久久无码区| 久久久精品久久久久特色影视| 久久亚洲私人国产精品| 久久精品成人欧美大片| 国产精品久久久久…| 亚洲另类欧美综合久久图片区| 久久精品www人人爽人人| 久久精品国产99久久丝袜| 久久超碰97人人做人人爱| 亚洲精品WWW久久久久久| 成人国内精品久久久久影院VR| 日韩人妻无码一区二区三区久久 | 97久久精品国产精品青草| 日韩AV毛片精品久久久| 久久亚洲精品视频| 欧美丰满熟妇BBB久久久| 99久久国产亚洲综合精品| 久久免费99精品国产自在现线| 色噜噜狠狠先锋影音久久| 69久久精品无码一区二区| 性色欲网站人妻丰满中文久久不卡| 性高湖久久久久久久久AAAAA| 久久夜色精品国产www| 国产精品va久久久久久久| 一本色道久久88加勒比—综合| 国产欧美久久一区二区| avtt天堂网久久精品| 国产亚洲欧美成人久久片 | 久久精品一区二区三区AV| 亚洲人成无码www久久久| 国产精品热久久无码av| 久久久久久A亚洲欧洲AV冫| 久久精品国产一区二区|