关于CSeq,RAck,以及CANCEL,ACK的特殊性

 

RFC3261和RFC3262分别对Cseq,RAck做了定义的,但是在应用过程中往往不明白它们的意义,导致出错。
The Call-ID of the request MUST be set to the Call-ID of the dialog.
   Requests within a dialog MUST contain strictly monotonically
   increasing and contiguous CSeq sequence numbers (increasing-by-one)
   in each direction (excepting ACK and CANCEL of course, whose numbers
   equal the requests being acknowledged or cancelled). 
 
以上是RFC3261对一个Request中CSeq的要求。
对一个会话,UAC侧和UAS侧的CSeq都是按1递增的,不过CANCEL和ACK例外,它们这两个的CSeq和INVITE一致。例如:
-->INVITE CSeq: 1 INVITE
<--100 CSeq: 1 INVITE
<--183 CSeq: 1 INVITE
-->PRACK CSeq: 2 PRACK
<--200(PRACK) CSeq: 2 PRACK
-->CANCEL CSeq: 1 CANCEL
<--200(CANCEL) CSeq: 1 CANCEL
<--487 CSeq: 1 INVITE
-->ACK CSeq: 1 ACK
 
UAC侧和UAS侧的CSeq是单独的,没有关联性,只是对于Response来说,它的CSeq需要和它对应的Request一致。
再列出两个例子:
-->INVITE CSeq: 1 INVITE
<--100 CSeq: 1 INVITE
<--183 CSeq: 1 INVITE
-->PRACK CSeq: 2 PRACK
<--200(PRACK) CSeq: 2 PRACK
-->UPDATE CSeq: 3 UPDATE
<--200(UPDATE) CSeq: 3 UPDATE
<--200(INVITE) CSeq: 1 INVITE
-->ACK CSeq: 1 ACK
-->BYE CSeq: 4 BYE
<--200(BYE) CSeq: 4 BYE
 
-->INVITE CSeq: 1 INVITE
<--100 CSeq: 1 INVITE
<--183 CSeq: 1 INVITE
-->PRACK CSeq: 2 PRACK
<--200(PRACK) CSeq: 2 PRACK
-->UPDATE CSeq: 3 UPDATE
<--200(UPDATE) CSeq: 3 UPDATE
<--200(INVITE) CSeq: 1 INVITE
-->ACK CSeq: 1 ACK
<--INVITE CSeq: 14 INVITE
-->200(INVITE) CSeq: 14 INVITE
<--ACK CSeq: 14 ACK
<--BYE CSeq: 15 BYE
-->200(BYE) CSeq: 15 BYE
 
PRACK中有RAck这个Header,这个Header同样让人困惑。
 The RAck header is sent in a PRACK request to support reliability of
   provisional responses.  It contains two numbers and a method tag.
   The first number is the value from the RSeq header in the provisional
   response that is being acknowledged.  The next number, and the
   method, are copied from the CSeq in the response that is being
   acknowledged.  The method name in the RAck header is case sensitive.
   Example:
      RAck: 776656 1 INVITE
上面是RFC3262中对RAck的定义。
RAck的格式是:
RAck: RSeq CSeq Method
RSeq是对应的183中的Rseq,CSeq是对应的183中的CSeq,也就是INVITE的CSeq。Method是INVITE。
另外要注意的是,183重发时,每次RSeq的值是按1递增。
例子:
-->INVITE CSeq: 1 INVITE
<--100 CSeq: 1 INVITE
<--183 CSeq: 1 INVITE RSeq:100
-->PRACK CSeq: 2 PRACK  RAck: 100 1 INVITE
<--200(PRACK) CSeq: 2 PRACK
<--183 CSeq: 1 INVITE RSeq:101
-->PRACK CSeq: 3 PRACK  RAck: 101 1 INVITE
<--200(PRACK) CSeq: 3 PRACK
-->CANCEL CSeq: 1 CANCEL
<--200(CANCEL) CSeq: 1 CANCEL
<--487 CSeq: 1 INVITE
-->ACK CSeq: 1 ACK
 
转自:
http://fypz.spaces.live.com/blog/cns!32BE3D7E15D984F4!462.entry

你可能感兴趣的:(header,dialog,each,rack,Numbers)