sip消息拆包原理及组包流程

yizhihongxing
操作系统 :CentOS 7.6_x64     
freeswitch版本 :1.10.9
sofia-sip版本: sofia-sip-1.13.14
 
freeswitch使用sip协议进行通信,当sip消息超过mtu时,会出现拆包的情况,这里整理下sip消息拆包原理及组包流程。

一、拆包的原理

 简单来说:拆包的原因是,sip消息过长,超过mtu值。
 具体原理可以参考《TCP/IP详解 卷2:实现》第10章 : IP的分片与重装
sip消息拆包原理及组包流程

这里贴下拆包的示意图:

sip消息拆包原理及组包流程

二、生成sip拆包的pcap文件

1、让sip消息超过mtu值

这里列举两种方法让sip消息超过mtu值,具体如下:
1) 添加sip消息内容,超出默认mtu值
该方法和真实场景比较贴合,建议使用,可以通过在orginate时添加自定义sip头实现,具体操作步骤获取途径:
关注微信公众号(聊聊博文,文末可扫码)后回复 20230402 获取。
2)设置网卡的mtu为比较小的值
一般网卡默认的mut值是 1500 ,可以通过以下命令修改:
ifconfig enp0s3 mtu 500up

其中,500是新的mtu值,具体效果如下:

sip消息拆包原理及组包流程

2、抓包获取pcap文件

为了方便起见,这里以修改mtu值的方式演示下。
这里使用tcpdump进行抓包,具体如下:
tcpdump -i enp0s3 udp -w sipTest1-mtu.pcap
具体效果如下:
sip消息拆包原理及组包流程

上图的INVITE消息已经拆包了。

组包时,需要看ip头里面的 More fragments 标识,拆包的数据Identification字段一致,在本示例里面是 22448 这个值。

三、sip消息组包

由于拆包是IP层的行为,sip消息大多基于udp实现,拆包的数据包里面可能没有端口信息(端口数据在udp里面定义的),解析之前需要先进行组包,这里以python为例进行演示。
python版本:python 3.9
libpcap版本:1.11.0b7
python3如何使用libpcap的具体讲解,可从如下途径获取:
关注微信公众号(聊聊博文,文末可扫码)后回复 2022102901  获取。

1、基于udp实现的sip协议数据报文结构

完整的sip消息的IP数据报有IP首部、UDP首部、UDP数据组成,具体如下:
sip消息拆包原理及组包流程

 

 其中IP首部为20字节,结构如下:

sip消息拆包原理及组包流程

UDP首部为8字节,结构如下:

sip消息拆包原理及组包流程

2、解析IP首部及UDP首部

ip首部解析如下:
ipHdr = struct.unpack('!BBHHHBBH4s4s',bytes(p[14:34]))
ver = (ipHdr[0] & 0xF0) >> 4
udp首部解析如下:
udpHdr = struct.unpack('!HHHH',bytes(p[34:42]))
srcPort,dstPort = udpHdr[0],udpHdr[1]

3、拼接SIP消息

解析过程大概分为以下几个步骤:
1)解析ip头及udp头;
2)判断ip头是否有moreFrag标识,如果有,则进行特殊标记处理;
3)根据数据包标识拼接sip消息,然后解析;
运行效果如下:
sip消息拆包原理及组包流程

拼接效果如下:

sip消息拆包原理及组包流程

示例代码如下:

sip消息拆包原理及组包流程

 

 四、资源获取

本文涉及文件和完整python示例代码从如下途径获取:

关注微信公众号(聊聊博文,文末可扫码)后回复 20230408 获取。
sip消息拆包原理及组包流程

原文链接:https://www.cnblogs.com/MikeZhang/p/sipParse20230408.html

本站文章如无特殊说明,均为本站原创,如若转载,请注明出处:sip消息拆包原理及组包流程 - Python技术站

(0)
上一篇 2023年4月18日
下一篇 2023年4月18日

相关文章

  • Python实现计算对象的内存大小示例

    一、Python实现计算对象的内存大小 要计算Python对象(例如列表、字典、自定义对象等)的内存大小可以使用Python的sys模块中的getsizeof()函数,并且可以通过递归计算其子对象的内存大小。getsizeof()函数计算的对象内存大小为对象所占内存空间的字节数(bytes)。 示例1:计算Python列表对象的内存大小 import sys…

    python 2023年6月3日
    00
  • python 将字符串转换成字典dict的各种方式总结

    下面是Python将字符串转换成字典的各种方式总结以及两个示例说明。 简介 将字符串转换为字典是Python编程中的常见需求。Python提供了多种方法将字符串转换为字典,例如使用字典解析、eval函数、json模块等。在下面的攻略中,将详细介绍Python将字符串转换成字典的各种方式。 方法一:使用字典解析 字典解析是一种Python语言中的高级技巧,可以…

    python 2023年5月13日
    00
  • python字典与json转换的方法总结

    Python字典与JSON格式是Python编程中非常常用的格式,本文主要介绍Python字典与JSON转换的方法总结。 将Python字典转换为JSON格式 Python内置模块json提供了将Python对象转换为JSON格式的方法。可以使用json.dumps()方法将Python字典转换为JSON字符串,代码示例如下: import json my_…

    python 2023年5月13日
    00
  • Python 给下载文件显示进度条和下载时间的实现

    使用urllib库下载文件并显示进度条和下载时间 首先,我们需要导入必要的库:urllib.request、tqdm、time。 import urllib.request from tqdm import tqdm import time 然后,我们定义一个函数来下载文件。这个函数需要传入两个参数:文件的url和保存路径。 def download_fil…

    python 2023年6月2日
    00
  • Python爬虫:url中带字典列表参数的编码转换方法

    当Python爬虫需要将字典或列表参数作为查询参数添加到URL链接中时,需要对其进行编码转换,否则在程序访问该链接时可能出现问题。以下是完整的攻略: 1. 理解URL的编码格式 URL编码格式指将URL链接中的特殊字符使用特定的编码方式进行转换,使得这些字符能够被顺利传递且不造成歧义。常见的URL编码方式为UTF-8编码方式。 例如,对于一个URL链接 ht…

    python 2023年5月31日
    00
  • Python 3.8.10 中的 ‘open(“file_path”)’ 和 ‘with open(“file_path”)’ 有什么区别,哪个最适合使用? [复制]

    【问题标题】:What is the difference between ‘open(“file_path”)’ and ‘with open(“file_path”)’ in Python 3.8.10 and which one is most suitable to use? [duplicate]Python 3.8.10 中的 ‘open(“fi…

    Python开发 2023年4月8日
    00
  • python用tkinter实现一个gui的翻译工具

    下面是详细讲解“Python用Tkinter实现一个GUI的翻译工具”的完整攻略。 1. 确定需求 在开始编写Python GUI应用之前,需要先确定应用的功能和界面设计。在这个例子中,我们需要一个翻译工具的GUI界面,用户可以输入需要翻译的文本,然后选择翻译的源语言和目标语言进行翻译,并将翻译结果显示在GUI界面上。 为了实现这个应用,我们需要调用第三方翻…

    python 2023年6月3日
    00
  • Python 并行化执行详细解析

    Python并行化执行是指在Python中使用多线程或多进程技术,实现并行化执行任务,提高程序的执行效率。本文将讲解Python并行化执行的详细解析,包括以下几个方面: Python多线程和多进程的区别 Python多线程的实现方法 Python多进程的实现方法 实践示例 Python多线程和多进程的区别 Python多线程和多进程都是实现并行化执行任务的方…

    python 2023年5月15日
    00
合作推广
合作推广
分享本页
返回顶部