1、背景

在调试UDP协议时,总是会遇到需要查看UDP报文的内容情况,或许是为了验证自己写的序列化组包是否正确,或者接受到的报文是否合法,亦或是为了查看自己发送或者接收的报文频率是否合格。无论出于什么目的,都要查看报文原始内容。在进行这一工作时,总是要百度搜tcpdump,还要搜UDP协议格式,还得搜IP协议格式。所以特此综合网络上的先者们的优秀博文。方便有此种特定需求场景的后者们参考。

2、tcpdump工具使用方式

简介:

tcpdump命令行工具的详细使用方法,可以仔细通读man手册。

man tcpdump

参数有很多,但如果掌握如下几个参数就可以满足大部分的调试场景了:

  • -i:interface 指定要监听的网卡。
  • -nn:表示以ip和port的方式显示来源主机和目的主机,而不是用主机名和服务。
  • -A:以ascii的方式显示数据包,抓取带有字符串的数据包时可以很方便的看到对应的字符串内容。
  • -X:数据包将会以16进制(左)ascii(右)的方式分两排显示,方便对照。
tcpdump [-i 网卡] -nnAX '规则表达式'

规则表达式

规则表达式中要使用关键字并且要遵从特定的语法要求。

常用的关键字有:

  • host:主机;
  • port:端口;
  • src host:发包主机;
  • dst host: 收包主机。
  • and、or、!:逻辑"与""或""非",多个条件时可以组合使用,更多的使用可以查看 man 7 pcap-filter

实例:

# 查看本机发往ip为10.1.5.11的主机的11262端口号的报文
tcpdump -i eth0 -nnX 'dst host 10.1.5.11 and port 11262'

截取一个报文示例如下:

15:16:07.849810 IP 10.1.5.6.42481 > 10.1.5.11.11262: UDP, length 860x0000:  4500 0072 7f16 4000 4011 9d52 0a01 0506  E..r..@.@..R....0x0010:  0a01 050b a5f1 2bfe 005e 1e82 fafb 0101  ......+..^......0x0020:  2205 004b 46b2 1422 8dcd 4c6e 6466 0606  "..KF.."..Lndf..0x0030:  a917 2765 3644 64db 81d8 0000 44ab 000d  ..'e6Dd.....D...0x0040:  ef00 10ca 0032 0cc6 e5bf 6a08 7b37 f5c8  .....2....j.{7..0x0050:  b104 1c78 f4e4 cbbb a20a 1cb7 eecb c002  ...x............0x0060:  afff 226f fce6 cb00 097f 0011 0c00 6250  .."o..........bP0x0070:  eced    

3、报文分析

通过tcpdump工具获取到了发送或接收到的报文包,但是如何读取,还需要了解UDP报文格式。

UDP报文格式

UDP协议和TCP协议同位于传输层,介于网络层(IP)和应用层之间。

UDP数据部分为应用层报文,而UDP报文再向下层(OSI七层网络模型)网络层(IP协议)传递时,会被加上IP协议头。

一个通用的IP报文的示例如下图所示:

IP首部:

UDP首部

linux下使用tcpdump工具分析UDP报文相关推荐

  1. linux服务器udp抓包工具,Linux下抓包工具tcpdump使用介绍

    点评:在传统的网络分析和测试技术中,嗅探器(sniffer)是最常见,也是最重要的技术之一,本文将介绍Linux下抓包工具tcpdump使用,需要的朋友可以参考下 在传统的网络分析和测试技术中,嗅探器 ...

  2. linux下 抓包工具下载,Linux下抓包工具tcpdump使用介绍

    Linux下抓包工具tcpdump使用介绍 发布时间:2012-11-30 17:11:39   作者:佚名   我要评论 在传统的网络分析和测试技术中,嗅探器(sniffer)是最常见,也是最重要的 ...

  3. arm linux下交叉编译valgrind工具进行内存泄露检测和性能分析

    C/C++等底层语言在提供强大功能及性能的同时,其灵活的内存访问也带来了各种纠结的问题.如果crash的地方正是内存使用错误的地方,说明你人品好.如果crash的地方内存明显不是consistent的 ...

  4. Linux下C++开发工具介绍

    概述     就C++开发工具而言,与Windows下微软(VC, VS2005等)一统天下相比,Linux/Unix下C++开发,可谓五花八门,各式各样.Emacs, vi, eclipse, an ...

  5. linux抓包库libpcap,linux下libpcap抓包分析.doc

    linux下libpcap抓包分析 HYPERLINK "/Seiyagoo/archive/2012/04/28/2475618.html" linux下libpcap抓包分析 ...

  6. Linux 下的编程工具

    Linux 下的编程工具 BBS水木清华站∶精华区 发信人: Kongming (没日没夜...), 信区: Linux         标  题: Re: 如何学习linux下编程?  发信站: B ...

  7. linux tcp 丢包命令_在Linux下实现测试TCP和UDP的丢包检测!

    在Linux下实现测试TCP和UDP的丢包检测! 疯狂の猿猴 • 2020 年 12 月 11 日 前言 本人平时基本上都是win,一下子转战到linux,有点不习惯! 因此做个记录,便于以后自己查阅 ...

  8. Linux下的parted工具的使用 GPT分区安装系统

    安装系统是安装前时候ctrl+atl+F2 fdisk -l parted select /dev/sdb mklabel msdos # 将GPT磁盘格式化为MBR磁盘 对大硬盘进行分区 xfs 和 ...

  9. Linux下暴力破解工具Hydra详解

    Linux下暴力破解工具Hydra详解 一.简介 Number one of the biggest security holes are passwords, as every password s ...

最新文章

  1. SpringBoot无法书写主启动类的情况之一
  2. 用new关键字对一个String 变量赋值和用literal值直接赋值有什么不同(转)
  3. HTTP状态码及含义
  4. YOLOv3剪枝再升级!
  5. SQL 分页查询的四种方法
  6. [USACO14OPEN]Fair Photography【前缀和】
  7. 个人收藏的一些实用网站整理
  8. JDK Required: 'tools.jar' seems to be not in IDEA classpath解决办法
  9. Java数据结构和算法-图
  10. 老友记中经典高频口语100句
  11. c语言开发无人机自动驾驶仪,无人机自动驾驶仪.pdf
  12. cesium实现动态圆效果之——螺旋圆
  13. 卷积神经网络中卷积的作用与原理
  14. 浙大python习题超详细思路(第二章)
  15. 百度编辑器ueditor上传视频后,再次编辑视频无法播放
  16. Java 由今天往前推7天怎么算
  17. 如何在Power BI中实现主页显示一个月,Tools显示前N个月的数据?
  18. Python操作Excel的Xlwings教程(五)
  19. windows下载安装mysql教程
  20. 网易2020校招笔试 系统开发研发工程师(提前批)牛客练习 Apare_xzc

热门文章

  1. HDU2182 Frog —— 简单DP
  2. 微信公众号怎么生成带参数的二维码?
  3. Ubuntu 设置 OpenDNS
  4. 邮票问题---动态规划
  5. 超级强大的五个资源网站 想要的资源都有
  6. pdf合并小工具python
  7. android系统软件卸载_adb配置使用
  8. matlab的无穷大怎样表示_matlab中从一到无穷大怎么表示
  9. Web 架构师的能力 转载之程序员官方blog
  10. 继电器的工作原理、构成和功能介绍