SIP与SDP Offer/Answer模型详解
需积分: 9 168 浏览量
更新于2024-09-10
收藏 52KB DOC 举报
"SIP使用SDP Offer/Answer模型在建立对话时遵循RFC3261、RFC3262和RFC3264的规范。该模型主要涉及SIP INVITE消息、可靠响应、ACK消息以及1xx中间响应中的Offer和Answer交互。"
在SIP(Session Initiation Protocol)中,SDP(Session Description Protocol)用于描述会话的媒体特性,如音频、视频等。Offer/Answer模型是SIP中建立会话的一个关键机制,它确保了通信双方能够协商一致的媒体参数。以下是这个模型的一些核心要点:
1. 初始Offer通常在INVITE消息中发送,或者在第一个可靠的非失败响应(通常是2xx响应)中。RFC3261后来扩展了这一规定,允许1xx(除了100 Trying)响应也作为可靠的响应。
2. 如果初始Offer在INVITE中,Answer必须在后续的可靠非失败响应中。如果Answer出现在1xx响应(如183),UAC(User Agent Client)将忽略同一事务后续的Answer。
3. 若初始Offer在非失败响应中,Answer应出现在对那个响应的ACK消息中。
4. 发送或接收了对前一个Offer的Answer后,UAC可以发送新的Offer。反之,没有确认Answer,不应发送新Offer。
5. UAS(User Agent Server)在INVITE事务的后续响应中不应携带新的Offer,除非已经收到对前一个Offer的Answer。RFC3262引入PRACK方法增强了1xx响应的可靠性。
6. 如果INVITE带有Offer,UAS需在可靠非失败响应(包括1xx)中返回Answer。PRACK用来确保1xx响应的可靠性,并且在PRACK中可以携带Answer或新的Offer。
7. 成功的Offer/Answer交互可以在INVITE事务完成前建立会话。1xx响应中的Offer要求在收到PRACK确认之前,UAS不能发送2xx响应。
8. RFC3264规定,Offer提出媒体选项,Answer则接受或拒绝这些选项。通过新的Offer/Answer交互,用户代理可以更新已建立的会话。
这个模型确保了SIP会话的两端能够有效地协商媒体参数,从而实现双向通信。理解并正确应用这些规则对于开发和维护SIP应用程序至关重要,因为它关系到会话的建立、媒体流的协商以及会话的更新。
2014-08-12 上传
2013-08-28 上传
2023-03-05 上传
2024-04-18 上传
2023-09-11 上传
2023-08-13 上传
2024-10-31 上传
2023-05-30 上传
2023-06-02 上传
Jenuce
- 粉丝: 2
- 资源: 10
最新资源
- ema-for-mei-js:TypeScript中MEI的EMA实现(同构)
- cplusplus-helloworld:这是我的第一个C ++项目
- ng-bootstrap-loading:角度页面的加载蒙版显示功能
- johaneous.github.io:韦伯斯特无删节词典(免费的En-En-Cht词典)
- 超级万年历记录时间过程与节气,纪念日的C++版本的实现
- api-cng
- 基于Docker的MySQL+Bind9-dlz一主多从高可用DNS方案.zip
- node-webapp-step1:用于学习外语学习网络应用程序开发
- CalDash:CS294 Web应用程序
- 个人档案袋:个人档案库
- quickplot:这是quickplot模块的测试版,是pandas,matplotlib和seaborn的包装,用于快速创建漂亮的Viz进行分析
- DlvrMe-API
- azuredemoapp
- test2-solutions:CMP237 测试 2 实践解决方案
- emsi-devops:这是霍尔伯顿学校项目的资料库
- Finite-State-Machine-Model:延续2018年夏季开始的项目,其中Graeme Zinck和我在Ricker博士的带领下制作了Finite State Machines的专业模型,以实施理论并为正在进行的研究提供了试验平台。 允许生成FSM,并执行多项操作(例如“产品”和“并行组合”),并且目前已集成了U结构以用于进一步分析。 目前正在为Mount Allison大学的Ricker博士开发此工具。