【接口协议与抓包】04.使用TcpDump + WireShark抓包分析三次握手与四次挥手

你好啊!我是山茶,一个探索 AI + 测试的程序员,欢迎与我沟通!

对于三次握手与四次挥手的理解与基本讲解可见上一篇

那么具体的请求是什么样的呢?使用 TCPDump + WireShark 对 TCP 三次握手与四次挥手展示

协议分析工具

  • 网络监听:TcpDump + WieSha

  • 代理Proxy

    • 在测试开发工作中较为推荐使用:Charles[适用于全平台,使用广泛]、安全测试:burpsuite[java全平台]
    • 自动化测试中也可以使用:mitmproxy
    • 其他代理有:fiddler[在windos中使用]、AnyProxy[全平台]
  • 协议客户端工具:curl、postman、apipost等使用较为广泛

tcpdump简介

用简单的话来定义tcpdump,就是:dump the traffic on a network,根据使用者的定义对网络上的数据包进行截获的包分析工具。

tcpdump可以将网络中传送的数据包的"头"完全截获下来提供分析。它支持针对网络层、协议、主机、网络或端口的过滤,并提供and、or、not等逻辑语句来帮助你去掉无用的信息。

常用参数

  • -x 十六进制展示

  • -w file 保存数据包文件

  • 表达式

    • ip tcp协议

    • host 主机名

    • port 80

    • src 来源 dst 目的

    • and or () 逻辑表达式

更多内容参见 tcpdump --help

使用TcpDump抓取数据分析

操作步骤

  • 服务器上使用tcpdump指令,发起监控

  • 服务器访问百度,获取数据消息

  • 停止tcpdump

  • 将tcpdump数据在wirshark中打开

  • 分析wireshark中打开的数据

arduino 复制代码
服务器开启对百度的监控,监控结果存入到 /home 下的 tcpdump.log的文件中
tcpdump host www.baidu.com -w /home/tcpdump.log
arduino 复制代码
新开服务器标签,使用 curl 指令访问百度网址,获取数据
curl https://www.baidu.com/

将对应的tcpdump数据文件日志导入到wireshark中

首行标题中包含几个字段,分别为"时间"、"源ip"、"目标ip"、"协议类型"、"数据大小"、"数据内容"

WireShark解析三次握手与四次挥手

三位握手与四次挥手🙋过程主要在以下框框中。

三次握手请求

  • 发送请求标志SYN = 1
  • 服务端响应并发送请求标志ACK = 1,SYN = 1
  • 客户端响应,双向数据连接通道建立成功ACK = 1

四次挥手过程

  • 客户端接收数据响应ACK = 1,发送结束请求标志FIN = 1
  • 服务端响应客户端请求ACK = 1,结束客户端到服务端的数据通道
  • 服务端发起断开请求FI N = 1
  • 客户端响应 ACK = 1,服务端端开连接,客户端等待2msl后端开,四次挥手过程端开c/s端双想数据通道

💡注意⚠️:在分析wireshark协议日志数据时需要区分清,发起请求来源ip与目标ip,以及对应的端口是否正确

相关推荐
invicinble12 小时前
这里对java的知识体系做一个全域的介绍
java·开发语言·python
小码哥_常12 小时前
MyBatis-Plus:让数据库操作飞起来的神器
后端
wbs_scy12 小时前
【Linux 线程进阶】进程 vs 线程资源划分 + 线程控制全详解
java·开发语言
ss27312 小时前
食谱推荐系统功能测试如何写?
java·数据库·spring boot·功能测试
2301_8112743112 小时前
基于SpringBoot的智能家居管理系统
spring boot·后端·智能家居
AI人工智能+电脑小能手12 小时前
【大白话说Java面试题】【Java基础篇】第15题:JDK1.7中HashMap扩容为什么会发生死循环?如何解决
java·开发语言·数据结构·后端·面试·哈希算法
舒一笑13 小时前
我把设备指纹生成逻辑拆开了:它到底凭什么区分不同设备?
后端·程序员·掘金技术征文
try2find13 小时前
打印ascii码报错问题
java·linux·前端
014-code13 小时前
CompletableFuture 实战模板(超时、组合、异常链处理)
java·数据库
Nicander13 小时前
多数据源下@transcation事务踩坑
java·后端