Sip协议(三)- 通话接听流程

2024-06-20 14:04
文章标签 sip 流程 协议 通话 接听

本文主要是介绍Sip协议(三)- 通话接听流程,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

Sip协议(三)- 通话接听流程

本文主要记录下sip通信下接听的流程.

一: 接听流程

  1. agent接听电话
  2. 远端在未接听情况下主动挂断电话.

接听流程涉及到的请求有: INVITE,CANCEL,ACK,BYE

具体的过程如下:

二: sip过程

  1. agent收到INVITE

    INVITE sip:1000@10.0.0.1:10000;transport=tcp SIP/2.0
    Via: SIP/2.0/TCP 10.0.0.1:5060;branch=z9hG4bKxxxx;rport=5060
    Route: <sip:1000@124.64.0.1:10988>;transport=tcp
    Max-Forwards: 70
    From: "Extension 1001" <sip:1001@172.17.0.1>;tag=Q79QQcg41UBpe
    To: <sip:1000@10.0.0.1:10000;transport=tcp>
    Call-ID: e040d830-a8aa-123d-0a8e-11111111111b
    CSeq: 84836083 INVITE
    Contact: <sip:mod_sofia@10.0.0.1:5060;transport=tcp>
    User-Agent: FreeSWITCH-mod_sofia/1.10.10-release~64bit
    Allow: INVITE, ACK, BYE, CANCEL, OPTIONS, MESSAGE, INFO, UPDATE, REGISTER, REFER, NOTIFY, PUBLISH, SUBSCRIBE
    Supported: path, replaces
    Allow-Events: talk, hold, conference, presence, as-feature-event, dialog, line-seize, call-info, sla, include-session-description, presence.winfo, message-summary, refer
    Content-Type: application/sdp
    Content-Disposition: session
    Content-Length: 426
    X-voice_call_number: 18300000000
    X-empolyee_id: 1001
    X-FS-Support: update_display,send_info
    Remote-Party-ID: "Extension 1001" <sip:1001@172.17.0.1>;party=calling;screen=yes;privacy=offv=0
    o=FreeSWITCH 1718762975 1718762976 IN IP4 10.0.0.1
    s=FreeSWITCH
    c=IN IP4 10.0.0.1
    t=0 0
    m=audio 16776 RTP/AVP 9 0 8 101
    a=rtpmap:9 G722/8000
    a=rtpmap:0 PCMU/8000
    a=rtpmap:8 PCMA/8000
    a=rtpmap:101 telephone-event/8000
    a=fmtp:101 0-15
    a=ptime:20
    m=video 16862 RTP/AVP 102
    b=AS:3072
    a=rtpmap:102 VP8/90000
    a=rtcp-fb:102 ccm fir
    a=rtcp-fb:102 ccm tmmbr
    a=rtcp-fb:102 nack
    a=rtcp-fb:102 nack pli
    
  2. agent发起 Trying 100

    SIP/2.0 100 Trying
    Via: SIP/2.0/TCP 10.0.0.1:5060;branch=z9hG4bK1111;rport=5060
    To: <sip:1000@10.0.0.1:10000;transport=tcp>
    From: "Extension 1001" <sip:1001@172.17.0.1>;tag=027KZHpcBFDXH
    Call-ID: 42ed1f48-a8ac-123d-0a8e-11111111111a
    CSeq: 84836381 INVITE
    Server: AgentTest/1.0.0/V2318A
    Content-Length: 0
    
  3. agent发起请求 Ringing 180

    180: 振铃中.

     SIP/2.0 180 RingingVia: SIP/2.0/TCP 10.0.0.1:5060;branch=z9hG4bKgvtvc29HgQZ5e;rport=5060To: <sip:1000@10.0.0.1:10000;transport=tcp>;tag=ec6c9cb5b93df28eFrom: "Extension 1001" <sip:1001@172.17.0.1>;tag=027KZHpcBFDXHCall-ID: 42ed1f48-a8ac-123d-0a8e-11111111111aCSeq: 84836381 INVITEServer: AgentTest/1.0.0/V2318AContent-Length: 204Content-Type: application/sdpv=0o=1000@10.0.0.1 0 0 IN IP4 10.239.19.29s=Session SIP/SDPc=IN IP4 10.239.19.29t=0 0m=audio 21000 RTP/AVP 8 101a=rtpmap:8 PCMA/8000a=rtpmap:101 telephone-event/8000a=fmtp:101 0-15
    
  4. agent接收到CANCEL请求

    CANCEL sip:1000@10.0.0.1:10000;transport=tcp SIP/2.0
    Via: SIP/2.0/TCP 10.0.0.1:5060;branch=z9hG4bKgvtvc29HgQZ5e;rport=5060
    Route: <sip:1000@124.64.22.13:10988>;transport=tcp
    Max-Forwards: 70
    From: "Extension 1001" <sip:1001@172.17.0.1>;tag=027KZHpcBFDXH
    To: <sip:1000@10.0.0.1:10000;transport=tcp>
    Call-ID: 42ed1f48-a8ac-123d-0a8e-11111111111a
    CSeq: 84836381 CANCEL
    Reason: SIP;cause=487;text="ORIGINATOR_CANCEL"
    Content-Length: 0
    
  5. agent回执 200

    SIP/2.0 200 OK
    Via: SIP/2.0/TCP 10.0.0.1:5060;branch=z9hG4bKgvtvc29HgQZ5e;rport=5060
    To: <sip:1000@10.0.0.1:10000;transport=tcp>
    From: "Extension 1001" <sip:1001@172.17.0.1>;tag=027KZHpcBFDXH
    Call-ID: 42ed1f48-a8ac-123d-0a8e-11111111111a
    CSeq: 84836381 CANCEL
    Server: AgentTest/1.0.0/V2318A
    Content-Length: 0
    
  6. agent回执487

    487: Request Terminated 请求被BYE或者CANCEL所终止.

     SIP/2.0 487 Request TerminatedVia: SIP/2.0/TCP 10.0.0.1:5060;branch=z9hG4bKgvtvc29HgQZ5e;rport=5060To: <sip:1000@10.0.0.1:10000;transport=tcp>From: "Extension 1001" <sip:1001@172.17.0.1>;tag=027KZHpcBFDXHCall-ID: 42ed1f48-a8ac-123d-0a8e-11111111111aCSeq: 84836381 INVITEServer: AgentTest/1.0.0/V2318AContent-Length: 0
    

这篇关于Sip协议(三)- 通话接听流程的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1078334

相关文章

Nginx分布式部署流程分析

《Nginx分布式部署流程分析》文章介绍Nginx在分布式部署中的反向代理和负载均衡作用,用于分发请求、减轻服务器压力及解决session共享问题,涵盖配置方法、策略及Java项目应用,并提及分布式事... 目录分布式部署NginxJava中的代理代理分为正向代理和反向代理正向代理反向代理Nginx应用场景

Spring Boot分层架构详解之从Controller到Service再到Mapper的完整流程(用户管理系统为例)

《SpringBoot分层架构详解之从Controller到Service再到Mapper的完整流程(用户管理系统为例)》本文将以一个实际案例(用户管理系统)为例,详细解析SpringBoot中Co... 目录引言:为什么学习Spring Boot分层架构?第一部分:Spring Boot的整体架构1.1

nodejs打包作为公共包使用的完整流程

《nodejs打包作为公共包使用的完整流程》在Node.js项目中,打包和部署是发布应用的关键步骤,:本文主要介绍nodejs打包作为公共包使用的相关资料,文中通过代码介绍的非常详细,需要的朋友可... 目录前言一、前置准备二、创建与编码三、一键构建四、本地“白嫖”测试(可选)五、发布公共包六、常见踩坑提醒

Ubuntu向多台主机批量传输文件的流程步骤

《Ubuntu向多台主机批量传输文件的流程步骤》:本文主要介绍在Ubuntu中批量传输文件到多台主机的方法,需确保主机互通、用户名密码统一及端口开放,通过安装sshpass工具,准备包含目标主机信... 目录Ubuntu 向多台主机批量传输文件1.安装 sshpass2.准备主机列表文件3.创建一个批处理脚

一个Java的main方法在JVM中的执行流程示例详解

《一个Java的main方法在JVM中的执行流程示例详解》main方法是Java程序的入口点,程序从这里开始执行,:本文主要介绍一个Java的main方法在JVM中执行流程的相关资料,文中通过代码... 目录第一阶段:加载 (Loading)第二阶段:链接 (Linking)第三阶段:初始化 (Initia

Git打标签从本地创建到远端推送的详细流程

《Git打标签从本地创建到远端推送的详细流程》在软件开发中,Git标签(Tag)是为发布版本、标记里程碑量身定制的“快照锚点”,它能永久记录项目历史中的关键节点,然而,仅创建本地标签往往不够,如何将其... 目录一、标签的两种“形态”二、本地创建与查看1. 打附注标http://www.chinasem.cn

通过Docker容器部署Python环境的全流程

《通过Docker容器部署Python环境的全流程》在现代化开发流程中,Docker因其轻量化、环境隔离和跨平台一致性的特性,已成为部署Python应用的标准工具,本文将详细演示如何通过Docker容... 目录引言一、docker与python的协同优势二、核心步骤详解三、进阶配置技巧四、生产环境最佳实践

MyBatis分页查询实战案例完整流程

《MyBatis分页查询实战案例完整流程》MyBatis是一个强大的Java持久层框架,支持自定义SQL和高级映射,本案例以员工工资信息管理为例,详细讲解如何在IDEA中使用MyBatis结合Page... 目录1. MyBATis框架简介2. 分页查询原理与应用场景2.1 分页查询的基本原理2.1.1 分

HTTP 与 SpringBoot 参数提交与接收协议方式

《HTTP与SpringBoot参数提交与接收协议方式》HTTP参数提交方式包括URL查询、表单、JSON/XML、路径变量、头部、Cookie、GraphQL、WebSocket和SSE,依据... 目录HTTP 协议支持多种参数提交方式,主要取决于请求方法(Method)和内容类型(Content-Ty

redis-sentinel基础概念及部署流程

《redis-sentinel基础概念及部署流程》RedisSentinel是Redis的高可用解决方案,通过监控主从节点、自动故障转移、通知机制及配置提供,实现集群故障恢复与服务持续可用,核心组件包... 目录一. 引言二. 核心功能三. 核心组件四. 故障转移流程五. 服务部署六. sentinel部署