linux过滤端口抓包_wireshark抓包工具的使用及分析

前段时间看到群里在讨论Wireshark抓包工具,想写一篇使用笔记但一直没来得及写,本篇就通过实例来分享wireshark抓包工具的使用。

Wireshark简介

Wireshark 是一个网络封包分析软件。网络封包分析软件的功能是撷取网络封包,并尽可能显示出最为详细的网络封包资料。

Wireshark下载、安装

下载链接:

https://www.wireshark.org/#download

b002c8a83ee631d0bf93b69ac940184a.png

官网下载速度较慢,在本公众号聊天界面回复关键字:Wireshark ,获取网盘链接,若链接失效可联系我获取。

安装与一般的PC机软件安装方式一样,按默认方式安装即可。

Wireshark的使用

我们就借助往期文章:C语言、嵌入式应用:TCP通信实例分析的TCP通信的demo来做演示。

实验框图如:

a3d1fada5192b58de8dac1b0295a851a.png

在本公众号聊天界面回复关键字:Wireshark,获取本次试验代码及工具:

ef97fd089f75483d8fd50a2ca36eb9f5.png

其中tcp_client为RT-Thread Studio工程,使用RT-Thread Studio工具导入之后,修改WiFi信息与你电脑连接的WiFi一致:

77c9d0cac90eed5dc07a301d55eb7021.png

编译下载到小熊派开发板即可。

启动Wireshark抓包工具,选择无线网卡:

2d58eaccd68cc1523faa8fc9d0186e3b.png

输入过滤信息ip.src == xxx.xxx.xxx.xxx or ip.dst == xxx.xxx.xxx.xxx,比如我这边是ip.src == 192.168.1.3 or ip.dst == 192.168.1.3

b4f1a6c5f71376bb49406c07bc92c71d.png

这样就可以只保留这个IP收发数据,如果不设置过滤信息则显示出来的分组太多了,不便于我们进行分析。

启动小熊派开发板串口终端及网络调试助手,然后互相发送数据:

d6ff5659c396faf4330ec66ae21bef37.png

此时Wireshark抓包工具抓取到了11条数据包:

37a7b2facdfd98387f9256bfde1bd8fd.png

通信双方只是互发一条字符串数据而已,怎么会产生11个数据包呢?

这是TCP通信所必须的,除了具体的数据包之外还包括了建立连接、断开连接过程需要的一些数据。

我们都知道TCP是一个可靠的、面向连接的传输层协议它建立连接有三次握手的过程、断开连接有四次挥手的过程:

68fa34bd9e607f92fe8183c6c24fbf91.png

d346302a35ef2eddec625225389d40f4.png

(图片来源:野火《LWIP应用开发实战指南》)

通俗的理解:

65e88a08df086f10c07f31c93eff9bca.png

4a1b3817706ba81b2f78e072a6c9cb3c.png

具体的握手、挥手过程本篇笔记不再展开,可阅读:【面试必考】TCP协议“三次握手”与“四次挥手”及【socket笔记】TCP、UDP通信总结

我们先来看这11个数据包是怎么划分的。打开Wireshark抓包工具的统计->流量图

f50f094a1fef69e7d61b2f98ccdd9c93.png

ebdecddabc8debd03eb5016995417bb9.png

下面,我们以第④个数据包来做具体的分析。在这之前我们先看一个图:

499ab4679c11b5d1800d3adf97214f84.png

(图片来源:野火《LWIP应用开发实战指南》)

从图中我们可以看到,从上到下看,各层数据是添加该层头部信息组成新的数据包,从下到上相反。我们来看我们抓到的数据包:

f10fe8a4db1686ed684801baeafc7282.png

选中相关信息,最下面的具体的数据同步高亮显示,如:

dce9efdb09b1e1c6fca63e8d94fa62e7.png

6b0e60140c51f14664f11cdb2aecf028.png

41878bf310fce13de0fb361671b11176.png

更具体的每个字节是什么,我们可以再展开:

55d03ddeffa68e4441292317d0bd1f5a.png

5c026349af0b38eb7bcaf778d44f06b0.png

至此,我们关于Wireshark抓包工具的基本使用就分享完了,知道了基本的使用及分析方法,我们就可以按照这样的方法去分析其它协议了。以上分享如有错误,欢迎指出,谢谢!

推荐资料:

1、野火《LWIP应用开发实战指南》

2、https://www.rt-thread.org/document/site/tutorial/qemu-network/wireshark/wireshark/

3、https://www.scaugreen.cn/posts/19508/

-THE END-


其他网友提问汇总

5428b233d7e8dd93fe97233b4f364dc7.gif

 1. 两个线程,两个互斥锁,怎么形成一个死循环?

5428b233d7e8dd93fe97233b4f364dc7.gif

 2. 一个端口号可以同时被两个进程绑定吗?

5428b233d7e8dd93fe97233b4f364dc7.gif

 3. 一个多线程的简单例子让你看清线程调度的随机性

5428b233d7e8dd93fe97233b4f364dc7.gif

 4. 粉丝提问|c语言:如何定义一个和库函数名一样的函数,并在函数中调用该库函数

推荐阅读

【1】 SPI转can芯片CSM300详解、Linux驱动移植调试笔记 必读 【2】 到底什么是Cortex、ARMv8、arm架构、ARM指令集、soc?一文帮你梳理基础概念【科普】 必读 【3】Linux面试题100道,看看会多少? 【4】Modbus协议概念最详细介绍 必读 【5】I2C基础知识入门 【6】 两个线程,两个互斥锁,怎么形成一个死循环? 【7】多路复用IO内幕  【8】 又一华为程序员进了ICU:压垮一个家庭,一张结算单就够了! 必读

本公众号全部原创干货已整理成一个目录,点击「干货」或者回复 1024 即可获得。

3aea83df62d6ed5ee11c4817944e935e.png

想加入嵌入式技术交流群请加一口君微信

一口君有问必答

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值