了解 RTSP 请求的 BNF 表示法

Understanding BNF notation for an RTSP request

根据 RTSP 文档第 21 页 https://www.rfc-editor.org/rfc/rfc2326,RTSP 响应是:

   Request      =       Request-Line          ; Section 6.1
                *(      general-header        ; Section 5
                |       request-header        ; Section 6.2
                |       entity-header )       ; Section 8.1
                        CRLF
                        [ message-body ]      ; Section 4.3

据我所知并根据 https://www.w3.org/Notation.html* 的意思是“它后面的一个或多个”。所以我将上面的内容解释为

*(general-header|request-header|entity-header)CRLF

这将解释下面的示例,其中 headers 属于 general-header \r\n 类型,如下所示:Cseq: 2\r\nContent-Base: rtsp://example.com/media.mp4\r\nContent-Type: application/sdp\r\nContent-Length: 360\r\n:

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"

headers 的格式为 general-header \r\n(其中 \r\n 是 CRLF)。但是消息 body 之前的那条额外的白线(\r\n)呢?这不是重复解释的。

我想我的解释有误。

这个解释是正确的:

Request = Request-Line *(general-header|request-header|entity-header) CRLF [message-body]

虽然给出的例子是一个响应,它有类似的语法:

Response = Status-Line *(general-header|response-header|entity-header) CRLF [message-body]

在任何一种情况下,header 的集合都通过 CRLF (\r\n) 与 message-body 分开,这不会重复。在示例中:

RTSP/1.0 200 OK                             # This is the Status-Line
CSeq: 2                                     # general-header (see Section 12)
Content-Base: rtsp://example.com/media.mp4  # entity-header (see Section 8.1, 12.11)
Content-Type: application/sdp               # entity-header (see Section 8.1, 12.16)
Content-Length: 460                         # entity-header (see Section 8.1, 12.14)
                                            # the CRLF marking the end of headers
m=video 0 RTP/AVP 96                        # the message body follows
...

* 之后的东西是括号块,没有 CRLF。每个 header 都以 CRLF 结尾,因为消息 headers 的语法包含它。参见第 4.2 节,其中引用 Section 4.2 of RFC 2068:

message-header = field-name ":" [ field-value ] CRLF