利用WireShark分析H264码流

转自http://blog.csdn.net/lu_embedded/article/details/69666414

背景:最近在参与一个ARM平台的音视频传输的项目,同事说已经是高清视频了,但是显示模糊,显然不能达到高清要求,于是就想抓包分析一下。


Step 1:执行如下命令,在 ARM 平台上用 tcpdump 抓包并保存为 test.cap。

tcpdump –i eth0 –nn –w test.cap
-i 网络接口,-nn:直接以 IP 及 port number 显示,而非主机名和服务名称
-w 如果你要将监听所得的封包资料储存下来,用这个参数就对了!后面接档名


 
 
  • 1-i 网络接

然后启动我们的多媒体通信程序,抓取几秒的数据即可。

Step 2:用 WireShark 工具打开 test.cap 文件。

Step 3:右键点击 H264 的 UDP 包,选择“Decode as…”,选择 RTP,点击 OK 之后就解析成 RTP 包了。把UDP 包解析成RTP/RTCP包。

Step 4:查看 RTP 包的 payload type,例如我们这里是102。
【Dynamic payload types which will be interpreted (理解)as H264; Values must be in the range 96 - 127】

这里写图片描述

Step 5:然后在 WireShark 工具栏中选择 Edit –> preferences –> protocols –> H264,把“H264 dynamic payload types”设成 102,点击 OK。把RTP Payload映射成实际的媒体格式。首先查看RTSP中的SDP的payload_type,比如96是H263,97是AMR。那么点击菜单Edit -> Preference -> Protocol, AMR payload_type number填写97, H263填写96,那么payload就可以自动解析了。

需要注意的是:
wireshark 1.0版本以上才支持H263和H264

这里写图片描述

Step 6:为方便查看,在 Filter 中输入“h264”过滤出 H264 数据包,如下。

这里写图片描述

Step 7:选择 SPS(Sequence Parameter Set)(序列参数集),展开 H.264 数据包,找到pic_width_in_mbs_minus1pic_height_in_map_units_minus1

这里写图片描述

Step 8:因此可以算出实际分辨率,X = (21+1)*16 = 352,Y = (17+1)*16 = 288,显然并不是高清视频。

实例1 使用wireshark抓包并检查丢包现象

(1)使用wireshark抓取所有UDP报文(这里假定RTP是基于UDP之上的)

(2)将抓取到的报文解析(解码)为RTP,如下图所示:



(3)分析报文(在报文较多且杂的情况下,可用excel导出数据查看),发现丢包:


Q、请教一下 我的序列包 为什么 不是按递增增长的 现在排序全是乱的 请问是什么原因引起的 您知道吗? 现在遇到坎了 感谢 帮助

A、点击下sequence number那一栏,看看有无排序的选项

Q、如果RTP是基于TCP的怎么办?decode as选项中没有RTP,只有RTPproxy怎么办?

A、RTP是可基于UDP或TCP的,基于TCP时,wireshark做decode,选项中就没有RTP和RTMP了。很头疼

问题来源于http://blog.csdn.net/acs713/article/details/19339707

  • 0
    点赞
  • 21
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值