软件测试学习笔记丨tcpdump 与 wireshark

news2024/10/9 17:49:12

本文转自测试人社区,原文链接:https://ceshiren.com/t/topic/32333

一、抓包分析TCP协议

1.1 简介

  • TCP协议是在传输层中,一种面向连接的、可靠的、基于字节流的传输层通信协议。

1.2 环境准备

  • 对接口测试工具进行分类:
  1. 网络嗅探工具:Tcpdump、wireshark
  2. 代理工具:Fiddler、Charles、Anyproxy、burp suite、Mitmproxy
  3. 分析工具:Curl、Postman、Chrome Devtool

二、Tcpdump

  • Tcpdump是一款将网络中传送的数据包的“头”完全截取下来,提供分析的工具。
    • 它支持针对网络层、协议、主机、网络或端口的过滤,并提供and、or、not等逻辑语句,去掉无用的信息。
    • 让Tcpdump时刻监听443端口,如果有异样就输入到log文件中。
      • 利用这条命令,会把得到的报告放到目录 /tmp/tcp.log 中。
sudo tcpdump port 443 -v -w /tmp/tcp.log
常用参数含义
port 443监听443端口
-x十六进制展示
-v输出更加详细的信息
-w把数据写到文件中

三、Wireshark

  • Wireshark也是一款网络嗅探工具,它除了拥有Tcpdump功能,还有更多扩展功能,比如分析工具,但是在接口测试中,抓包过程往往都是在服务器进行,服务器一般不提供UI界面,所以Wireshark无法在服务器工作,只能利用Tcpdump抓包生成log,然后将log导入Wireshark使用,在有UI界面的客户端上进行分析。

四、实战

1、抓取一个HTTP的GET请求:
(1)在百度搜mp3:http://www.baidu.com/s?wd=mp3
(2)用Tcpdump截获这个get请求,并生成log
(3)用Wireshark打开Tcpdump生成的log

  • 使用 Wireshark 查看 log,如图所示:

2、三次握手与四次挥手

  • log 的前几段信息是三次握手。因为信道是不可靠的,在发送数据前,就必须确保信道稳定,而三次握手就像是下面这些操作:

(1)第一次握手:建立连接时,客户端发送 syn 包(syn=j)到服务器,并进入 SYN_SENT 状态,等待服务器确认。
(2)第二次握手:服务器收到 syn 包,必须确认客户的 SYN(ack=j+1),同时自己也发送一个 SYN 包(seq=k),即 SYN+ACK 包,此时服务器进入 SYN_RECV 状态。
(3)第三次握手:客户端收到服务器的 SYN+ACK 包,向服务器发送确认包 ACK(ack=k+1),此包发送完毕,客户端和服务器进入 ESTABLISHED(TCP 连接成功)状态,完成三次握手,如图所示是三次握手的过程。

结束交流时,也需要进行四次挥手:

(1)第一次挥手:客户端向服务器端发送一个 FIN,请求关闭数据传输。
(2)第二次挥手:服务器接收到客户端的 FIN,向客户端发送一个 ACK,其中 ack 的值等于 FIN+SEQ。
(3)第三次挥手:服务器向客户端发送一个 FIN,告诉客户端应用程序关闭。
(4)第四次挥手:客户端收到服务器端的 FIN,回复一个 ACK 给服务器端。其中 ack 的值等于 FIN+SEQ。

注意: 一个请求可能分为多个包,一个数据也是这样,于是在 Wireshark 会看到很多包。

在这里插入图片描述

推荐学习

【霍格沃兹测试开发】7天软件测试快速入门带你从零基础/转行/小白/就业/测试用例设计实战

【霍格沃兹测试开发】最新版!Web 自动化测试从入门到精通/ 电子商务产品实战/Selenium (上集)

【霍格沃兹测试开发】最新版!Web 自动化测试从入门到精通/ 电子商务产品实战/Selenium (下集)

【霍格沃兹测试开发】明星讲师精心打造最新Python 教程软件测试开发从业者必学(上集)

【霍格沃兹测试开发】明星讲师精心打造最新Python 教程软件测试开发从业者必学(下集)

【霍格沃兹测试开发】精品课合集/ 自动化测试/ 性能测试/ 精准测试/ 测试左移/ 测试右移/ 人工智能测试

【霍格沃兹测试开发】腾讯/ 百度/ 阿里/ 字节测试专家技术沙龙分享合集/ 精准化测试/ 流量回放/Diff

【霍格沃兹测试开发】Pytest 用例结构/ 编写规范 / 免费分享

【霍格沃兹测试开发】JMeter 实时性能监控平台/ 数据分析展示系统Grafana/Docker 安装

【霍格沃兹测试开发】接口自动化测试的场景有哪些?为什么要做接口自动化测试?如何一键生成测试报告?

【霍格沃兹测试开发】面试技巧指导/ 测试开发能力评级/1V1 模拟面试实战/ 冲刺年薪百万!

【霍格沃兹测试开发】腾讯软件测试能力评级标准/ 要评级表格的联系我

【霍格沃兹测试开发】Pytest 与Allure2 一键生成测试报告/ 测试用例断言/ 数据驱动/ 参数化

【霍格沃兹测试开发】App 功能测试实战快速入门/adb 常用命令/adb 压力测试

【霍格沃兹测试开发】阿里/ 百度/ 腾讯/ 滴滴/ 字节/ 一线大厂面试真题讲解,卷完拿高薪Offer !

【霍格沃兹测试开发】App自动化测试零基础快速入门/Appium/自动化用例录制/参数配置

【霍格沃兹测试开发】如何用Postman 做接口测试,从入门到实战/ 接口抓包(最新最全教程)

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2199621.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

建筑物能耗模拟软件EnergyPlus下载安装及使用

建筑物能耗模拟软件EnergyPlus下载安装及使用 EnergyPlus概述EnergyPlus下载及安装EnergyPlus安装 EnergyPlus使用参考 建筑物能耗模拟软件是一种在建筑设计阶段使用的工具,能够透过电脑模拟预测未来建筑物的能耗情况,达成建筑性能模拟。这有助于评估不同…

技术总监详解:怎么用 Unity 引擎技术开发智能座舱 HMI 相关应用

想象一下,当启动车辆,眼前的屏幕瞬间点亮,呈现出一个逼真的 3D 城市景观,无论是清晨的第一缕阳光穿透云层,还是夜幕降临时霓虹灯下的繁华都市,都能够通过细腻的光影效果展现在眼前。3D HMI 方案提供直观、立…

Ethernet IP 转 Profinet网关在流量计中的应用

Ethernet/IP 和 Profinet 都是在工业自动化领域占据重要地位的工业以太网标准。 Ethernet/IP 是由美国罗克韦尔自动化公司开发的一种基于以太网的工业自动化通信协议。它采用 TCP/IP 协议栈,支持以太网和 TCP/IP 网络,具有高速、开放、互操作性强等特点…

重塑项目管理:角色认知的新视角与实践

在管理场景中,面对各种挑战时,你能否迅速切换至管理者视角来审视问题并作出反应,这直接反映了你的角色认知程度。角色认知往往在潜意识中起作用,自我难以察觉,但却能清晰地传达给他人,特别是当我们的行为与…

CDN绕过学习

1.什么是CDN? CDN就是分布在各个地区的服务器,这些服务器储存着数据的副本。 哪些服务器比较接近你,当你发起请求时,提前就会快速为你提供服务。 总结来说就是: 其实就是用来加速访问的,以及缓解压力&a…

原来机器学习这么简单——线性回归

引言: 在正文开始之前,首先给大家介绍一个不错的人工智能学习教程:https://www.captainbed.cn/bbs。其中包含了机器学习、深度学习、强化学习等系列教程,感兴趣的读者可以自行查阅。 一、什么是线性回归? 线性回归 是…

基于贝叶斯决策的 CAD 程序设计方案

✅作者简介:2022年博客新星 第八。热爱国学的Java后端开发者,修心和技术同步精进。 🍎个人主页:Java Fans的博客 🍊个人信条:不迁怒,不贰过。小知识,大智慧。 💞当前专栏…

大数据新视界 --大数据大厂之大数据与量子机器学习融合:突破智能分析极限

💖💖💖亲爱的朋友们,热烈欢迎你们来到 青云交的博客!能与你们在此邂逅,我满心欢喜,深感无比荣幸。在这个瞬息万变的时代,我们每个人都在苦苦追寻一处能让心灵安然栖息的港湾。而 我的…

Linux入门3——vim的简单使用

1.vim 1.1 vim的模式 vim有三种主要模式: ①命令模式:使用vim刚打开进入的模式就是命令模式; ②插入模式:只有在插入模式下才可以做文字输入,按[Esc]键可退回命令模式; ③末行模式:文件保存或退…

希亦超声波清洗机值得购买吗?清洁技术之王多维度测评大揭秘!

随着人们生活质量的提升,高质量眼镜愈发受到欢迎,但它们的清洁与保养却常常被疏忽,导致镜片蒙尘受损,影响佩戴者的视觉清晰度。为此,超声波眼镜清洗机作为一种新兴潮流应时而生,以其高效清洁眼镜及珠宝、精…

行盒的截断样式 box-decoration-break

1. 场景举例 当我们遇到如下场景时, 很多小伙伴可能会直接为这段文字添加边框和背景颜色,但往往会发现,效果并不如预期。出现的问题如下图所示,那么该如何解决呢? 这时就需要引入一个非常实用的 CSS 属性——box-deco…

元宇宙展厅的展示方式有哪些?

元宇宙展厅的展示方式多种多样,融合了虚拟现实以及多媒体交互等先进技术,为参观者提供了前所未有的沉浸式体验。以下是一些主要的展示方式: 1、虚拟现实(VR)展示: 利用VR技术,观众可以身临其境…

开关 switch

<el-table-column label"公开 | 隐藏" align"center" width"100"><template slot-scope"scope"><el-switchv-model"scope.row.dynamicStatus":active-value"1":inactive-value"0"active…

Windows11下 安装 Docker部分疑难杂症(Unexpecter WSL error)

装了大半天Docker desktop终于装好了&#xff0c;网上有的主流教程就不复述了&#xff0c;主要说一下网上没有的教程。 以下是遇到的问题&#xff1a; 首先&#xff0c;启用或关闭Windows确保里面与虚拟机有关的几个都要选上 没有Hyper-V参考此文 但是我这里都勾选了&#x…

多电源上电时序控制

多电源上电时序控制 我们如何给这种比如说有三个电源轨道&#xff0c;有这种上电时序先后次序要求的这种器件供电呢&#xff1f;那我们有大概以下几种方法。 1.直接使用前一时序电源的输出Vout做下一时序电源的使能EN 优点:简单&#xff0c;直观&#xff0c;成本低 缺点:要关…

电力电子技术03 AC-DC整流器(2)---单相半波整流器 二极管不控整流

半波整流器是一种简单的AC-DC整流电路&#xff0c;它将输入的交流电&#xff08;AC&#xff09;的一半&#xff08;正或负半周期&#xff09;转换为直流电&#xff08;DC&#xff09;。这种电路利用二极管的单向导电特性&#xff0c;在正半周期时允许电流通过&#xff0c;而在负…

75.【C语言】文件操作(2)

承接74.【C语言】文件操作(1)文章 目录 5.详细阐释文件的打开和关闭 1.流 2.标准流 3.文件指针 FILE 两层含义 附:FILE的头文件 4.操作文件的步骤 1.fopen函数 ​编辑 简写的全称查询 输入&输出的含义 2.fclose函数 3.代码示例 补充:绝对路径和相对路径 注意…

No.14 笔记 | XSS漏洞:原理、类型与防御策略

一、HTML和JavaScript基础 1. HTML基础 HTML概述&#xff1a;超文本标记语言&#xff0c;用于实现页面跳转和显示数据。结构标准&#xff1a;包括<!doctype html>声明文档类型&#xff0c;<html>根标签&#xff0c;<head>头部标签和<body>主体标签等。…

Markdown 语法详解大全(超级版)(四)——Markdown 使用 Emoji 表情 (附:表情符号简码列表)

Markdown 语法详解大全(超级版)&#xff08;四&#xff09; ——Markdown 使用 Emoji 表情 &#xff08;附&#xff1a;表情符号简码列表&#xff09; 本文目录&#xff1a; 一、复制和粘贴表情符号 二、使用表情符号简码 三、表情符号简码列表 本系列文章&#xff1a; Ma…

阿里云CDN设置阀值的指南

在如今这个信息爆炸的时代&#xff0c;网站的访问速度和用户体验变得尤为重要。阿里云CDN&#xff08;内容分发网络&#xff09;作为一种高效的解决方案&#xff0c;帮助用户加速网站内容的分发。然而&#xff0c;如何合理设置CDN的阀值&#xff0c;确保资源的高效利用&#xf…