SIP-メッセージング

SIPメッセージには2つのタイプがあります- requests そして responses

  • リクエストの開始行には、リクエストを定義するメソッドと、リクエストの送信先を定義するRequest-URIが含まれています。

  • 同様に、応答の開始行には応答コードが含まれています。

リクエストメソッド

SIP requests通信を確立するために使用されるコードです。それらを補完するために、SIP responses これは通常、リクエストが成功したか失敗したかを示します。

方法として知られているこれらのSIP要求は、SIPメッセージを実行可能にします。

  • 方法は、別のユーザーエージェントまたはサーバーによって実行される特定のアクションを要求するため、SIP要求と見なすことができます。

  • メソッドは2つのタイプに区別されます-

    • コアメソッド

    • 拡張メソッド

コアメソッド

以下で説明するように、6つのコアメソッドがあります。

招待する

INVITEは、ユーザーエージェントとのセッションを開始するために使用されます。言い換えると、INVITEメソッドは、ユーザーエージェント間のメディアセッションを確立するために使用されます。

  • INVITEには、メッセージ本文に発信者のメディア情報を含めることができます。

  • INVITEが成功応答(2xx)を受信した場合、またはACKが送信された場合、セッションは確立されたと見なされます。

  • INVITEリクエストが成功すると、 dialog BYEが送信されてセッションが終了するまで続く2つのユーザーエージェント間。

  • 確立されたダイアログ内で送信されるINVITEは、 re-INVITE

  • Re-INVITEは、セッションの特性を変更したり、ダイアログの状態を更新したりするために使用されます。

INVITEの例

次のコードは、INVITEの使用方法を示しています。

INVITE sips:[email protected] SIP/2.0 
   Via: SIP/2.0/TLS client.ANC.com:5061;branch = z9hG4bK74bf9 
   Max-Forwards: 70 
   From: Alice<sips:[email protected]>;tag = 1234567 
   To: Bob<sips:[email protected]>
   Call-ID: [email protected]  
   CSeq: 1 INVITE 
   Contact: <sips:[email protected]> 
   Allow: INVITE, ACK, CANCEL, OPTIONS, BYE, REFER, NOTIFY 
   Supported: replaces 
   Content-Type: application/sdp 
   Content-Length: ...  
   
   v = 0 
   o = Alice 2890844526 2890844526 IN IP4 client.ANC.com 
   s = Session SDP 
   c = IN IP4 client.ANC.com 
   t = 3034423619 0 
   m = audio 49170 RTP/AVP 0 
   a = rtpmap:0 PCMU/8000

さようなら

BYEは、確立されたセッションを終了するために使用される方法です。これは、セッションを終了するために発信者または着信者のいずれかが送信できるSIP要求です。

  • プロキシサーバーから送信することはできません。

  • BYEリクエストは通常​​、プロキシサーバーをバイパスしてエンドツーエンドでルーティングします。

  • BYEは、保留中のINVITEまたは確立されていないセッションに送信することはできません。

登録

REGISTERリクエストは、ユーザーエージェントの登録を実行します。このリクエストは、ユーザーエージェントからレジストラサーバーに送信されます。

  • REGISTERリクエストは、指定されたドメインの権限のあるレジストラに到達するまで転送またはプロキシされる場合があります。

  • それはAOR(レコードのアドレス)を運びます To 登録されているユーザーのヘッダー。

  • REGISTERリクエストには、期間(3600秒)が含まれています。

  • あるユーザーエージェントは、別のユーザーエージェントに代わってREGISTERリクエストを送信できます。これはとして知られていますthird-party registration。ここでは、From タグには、で識別された当事者に代わって登録を送信する当事者のURIが含まれています To ヘッダ。

キャンセル

CANCELは、確立されていないセッションを終了するために使用されます。ユーザーエージェントはこの要求を使用して、以前に開始された保留中の呼び出しの試行をキャンセルします。

  • これは、ユーザーエージェントまたはプロキシサーバーのいずれかによって送信できます。

  • キャンセルは hop by hop リクエスト、つまり、ユーザーエージェント間の要素を通過し、次のステートフル要素によって生成された応答を受信します。

ACK

ACKは、INVITEメソッドへの最終応答を確認するために使用されます。ACKは常にINVITEの方向に進みます。INVITEで使用できない場合、ACKにはSDP本体(メディア特性)が含まれる場合があります。

  • ACKを使用して、最初のINVITEですでに送信されているメディアの説明を変更することはできません。

  • ACKを受信するステートフルプロキシは、ACKを別のプロキシまたはユーザーエージェントにダウンストリームで転送する必要があるかどうかを判断する必要があります。

  • 2xx応答の場合、ACKはエンドツーエンドですが、他のすべての最終応答の場合、ステートフルプロキシが含まれている場合はホップごとに機能します。

オプション

OPTIONSメソッドは、ユーザーエージェントまたはプロキシサーバーにその機能についてクエリを実行し、現在の可用性を検出するために使用されます。要求への応答には、ユーザーエージェントまたはサーバーの機能が一覧表示されます。プロキシがOPTIONSリクエストを生成することはありません。

拡張メソッド

申し込む

SUBSCRIBEは、特定のイベントに関する通知を取得する目的でサブスクリプションを確立するためにユーザーエージェントによって使用されます。

  • それは含まれています Expires サブスクリプションの期間を示すヘッダーフィールド。

  • 期間が経過すると、サブスクリプションは自動的に終了します。

  • サブスクリプションは、ユーザーエージェント間のダイアログを確立します。

  • 有効期限が切れる前にダイアログ内で別のSUBSCRIBEを送信することにより、再度サブスクリプションを行うことができます。

  • ユーザーからのサブスクリプションに対して200OKが受信されます。

  • ユーザーは、有効期限の値が0(ゼロ)の別のSUBSCRIBEメソッドを送信することで、サブスクライブを解除できます。

通知

NOTIFYは、特定のイベントの発生を取得するためにユーザーエージェントによって使用されます。通常、NOTIFYは、サブスクライバーと通知機能の間にサブスクリプションが存在する場合にダイアログ内でトリガーされます。

  • すべてのNOTIFYは、通知機能によって受信された場合、200OK応答を受け取ります。

  • NOTIFYには Event イベントを示すヘッダーフィールドと subscriptionstate サブスクリプションの現在の状態を示すヘッダーフィールド。

  • NOTIFYは、サブスクリプションの開始時と終了時に常に送信されます。

公開

PUBLISHは、イベント状態情報をサーバーに送信するためにユーザーエージェントによって使用されます。

  • PUBLISHは、イベント情報のソースが複数ある場合に最も役立ちます。

  • PUBLISHリクエストは、ダイアログで送信されないことを除いて、NOTIFYに似ています。

  • PUBLISHリクエストには、 Expires ヘッダーフィールドと Min-Expires ヘッダーフィールド。

参照

REFERは、ダイアログのURIにアクセスするために別のユーザーエージェントを参照するためにユーザーエージェントによって使用されます。

  • REFERには、 Refer-Toヘッダ。これは、REFERの必須ヘッダーです。

  • REFERは、ダイアログの内側または外側に送信できます。

  • A 202 Accepted 他のユーザーエージェントが参照を受け入れたことを示すREFER要求をトリガーします。

情報

INFOは、メディアセッションを確立した別のユーザーエージェントにコールシグナリング情報を送信するためにユーザーエージェントによって使用されます。

  • これはエンドツーエンドのリクエストです。

  • プロキシは常にINFOリクエストを転送します。

更新

UPDATEは、セッションが確立されていない場合にセッションの状態を変更するために使用されます。ユーザーは、UPDATEを使用してコーデックを変更できます。

セッションが確立されると、re-Inviteを使用してセッションを変更/更新します。

PRACK

PRACKは、暫定応答(1XX)の信頼できる転送の受信を確認するために使用されます。

  • 通常、PRACKは、クライアントが以下を含む暫定応答を受信したときに生成されます。 RSeq 信頼できるシーケンス番号と supported:100rel ヘッダ。

  • PRACKには(RSeq + CSeq)の値が含まれています rack ヘッダ。

  • PRACKメソッドは、確実に転送されることのない100試行応答を除くすべての暫定応答に適用されます。

  • PRACKにはメッセージ本文が含まれる場合があります。オファー/アンサー交換に使用できます。

メッセージ

SIPを使用してインスタントメッセージを送信するために使用されます。IMは通常、テキスト会話に従事する参加者によってリアルタイムで交換される短いメッセージで構成されます。

  • MESSAGEは、ダイアログ内またはダイアログ外に送信できます。

  • MESSAGEの内容は、メッセージ本文に MIME アタッチメント。

  • A 200 OK 通常、応答はメッセージが宛先に配信されたことを示すために受信されます。