//------------------SIP基础------------------------//

SIP是基于UDP的协议

UA(user Agent)用户代理

UAC(client)发起SIP请求一方

UAS(server)接收请求并发送响应的一方

//SIP协议6中基本方法

REGISTER   注册联系信息

INVITE    初始化一个会话,可以理解为发起一个呼叫

ACK     对INVITE消息的最终响应

CANCEL    取消一个等待处理或正在处理的请求

BYE     终止一个会话

OPTIONS    查询服务器和能力,也可以用作ping测试

//扩展

SUBSCRIBE NOTIFY MESSAGE REFER INFO

//SIP必须包含的头域

Call-ID    用于区分不同会话的唯一标志

CSeq    顺序号,用于在同一会话中区分事务

From    说明请求来源

To     说明请求接收方

Max-Forwards  限制跳跃点数和最大转发次数

Via     描述请求消息经过的路径

//扩展的头域

Contact    Alice(某人)的联系地址

Expires    本次注册的有效期

Allow    Alice(某人)的UA所能支持的功能

User-Agent   UA的型号

Content-Length  消息正文的长度

//注册流程

  Alice           Freeswitch

    REGISTER(1)

  ---------------------------->

    SIP/2.0 401 unauthorized(未认证(http摘要认证))

  <----------------------------

    REGISTER(2)

  ---------------------------->

    SIP/2.0 200ok

  <----------------------------

//呼叫流程

  Bob            Alice

  INVITE alice@example.com

  ---------------------------->

    100Trying

  <----------------------------  //收到请求,等待响铃

    180Ringing

  <----------------------------  //响铃后回180,Bob收到180后提示对方正在响铃

    200OK

  <----------------------------  //Alice接听后,回200OK

    ACK

  ---------------------------->  //收到200OK回复ACK证实

    RTP

  --------------------------------------- //语音通话走的是SIP之外的RTP

    BYE

  <----------------------------  //Alice挂断

    200OK

   ---------------------------->  //收到BYE后回200OK

响应消息=状态码和原因短语(如Trying、Ringing)

1XX:为临时状态,表明呼叫的进展情况;

2XX:请求被成功收到;

3XX:重定向,SIP请求转到另一个UAS处理;

4XX:请求失败,一般由客户端或网络引起,如密码错误、空号

5XX:服务器内部错误,服务器出错不能响应错误的请求;

6XX:全局性错误,600 Busy Everywhere;

SIP协议栈基础笔记的更多相关文章

  1. 几种开源SIP协议栈对比OPAL,VOCAL,sipX,ReSIProcate,oSIP

    随着VoIP和NGN技术的发展,H.323时代即将过渡到SIP时代,在H.323的开源协议栈中,Openh323占统治地位,它把一个复杂而又先进 的H.323协议栈展现在普通程序员的眼前,为H.323 ...

  2. 几个重要的开源视频会议SIP协议栈

    视频会议系统由于需要与不同的终端进行连接,因此我们需要视频会议终端遵循统一的协议,H.323协议是视频会议软件使用最广泛的协议栈,但H.323设计得较为复杂,用户在调用H.323协议过程较多,因此利用 ...

  3. 几种开源SIP协议栈对比

    几种开源SIP协议栈对比 随着VoIP和NGN技术的发展,H.323时代即将过渡到SIP时代,在H.323的开源协议栈中,Openh323占统治地位,它把一个复杂而又先进的H.323协议栈展现在普通程 ...

  4. Java基础笔记 – Annotation注解的介绍和使用 自定义注解

    Java基础笔记 – Annotation注解的介绍和使用 自定义注解 本文由arthinking发表于5年前 | Java基础 | 评论数 7 |  被围观 25,969 views+ 1.Anno ...

  5. php代码审计基础笔记

    出处: 九零SEC连接:http://forum.90sec.org/forum.php?mod=viewthread&tid=8059 --------------------------- ...

  6. MYSQL基础笔记(六)- 数据类型一

    数据类型(列类型) 所谓数据烈性,就是对数据进行统一的分类.从系统角度出发时为了能够使用统一的方式进行管理,更好的利用有限的空间. SQL中讲数据类型分成三大类:1.数值类型,2.字符串类型和时间日期 ...

  7. MYSQL基础笔记(五)- 练习作业:站点统计练习

    作业:站点统计 1.将用户的访问信息记录到文件中,独占一行,记录IP地址 <?php //站点统计 header('Content-type:text/html;charset=utf-8'); ...

  8. MYSQL基础笔记(四)-数据基本操作

    数据操作 新增数据:两种方案. 1.方案一,给全表字段插入数据,不需要指定字段列表,要求数据的值出现的顺序必须与表中设计的字段出现的顺序一致.凡是非数值数据,到需要使用引号(建议使用单引号)包裹. i ...

  9. MYSQL基础笔记(三)-表操作基础

    数据表的操作 表与字段是密不可分的. 新增数据表 Create table [if not exists] 表名( 字段名 数据类型, 字段名 数据类型, 字段n 数据类型 --最后一行不需要加逗号 ...

随机推荐

  1. Python 3.x下消除print()自动换行

    Python 2.x下的print语句在输出字符串之后会默认换行,如果不希望换行,只要在语句最后加一个“,”即可.但是在Python 3.x下,print()变成内置函数,加“,”的老方法就行不通了. ...

  2. Centos 下安装 文泉驿 字体 Odoo

    刚装完centos下的odoo的字体 文泉驿 ,一万头草泥马呼啸而过.....劝君如非必要,千万别再centos下折腾odoo..... 正题,文泉驿官网 只提供 deb包和源码包的字体安装 ,想在c ...

  3. spark reduce类操作

    reduce类函数分析: ---------------------------------------------------------------------------- 待补全 ------ ...

  4. HDU1051 贪心

    Wooden Sticks Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others)Tot ...

  5. HTML静态网页 格式与布局

    一.position:fixed 锁定位置(相对于浏览器的位置),例如有些网站的右下角的弹出窗口. 示例: 二.position:absolute  相对于自己最近的父元素来定位的 1.外层没有pos ...

  6. CSS DIV 独占一行,清除左右两边的浮动

    clear:both //表示清除左右两边浮动的层,自己独占一行

  7. 前端技术-PS切图

    页面制作部分之PS切图 <--本标签下,通过页面制作.页面架构.javascript程序设计.DOM编程艺术.产品前端架构五部分来分享总结笔记,总结笔记会陆续分享--> 网页设计在技术层面 ...

  8. 本内容中发现无效字符。处理资源 'file:///C:/Users/XDJ/Desktop/1111/press.xml' 时出错。第 5 行,位置: 11 <author>ƽ

    粘贴到编译器中, 然后在复制出即可.

  9. Android课程---Android Studio简单设置

    Android Studio 简单设置 界面设置 默认的 Android Studio 为灰色界面,可以选择使用炫酷的黑色界面.Settings-->Appearance-->Theme, ...

  10. mysql 函数编程大全(持续更新)

    insert ignore insert ignore表示,如果中已经存在相同的记录,则忽略当前新数据 如果您使用一个例如“SET col_name = col_name + 1”的赋值,则对位于右侧 ...