Fiddler 工具的使用

news2025/1/19 20:30:20

文章目录

      • 01 Fiddler 工具介绍
        • 1. 下载与安装
        • 2. Fiddler 工具界面介绍
        • 3. Fiddler 工具的工作原理
      • 02 手工调用 HTTP 接口
        • 1. 发送HTTP请求
        • 2. 查看返回数据包
      • 03 获取 PC 端的网络数据包
      • 04 获取手机端的网络数据包
      • 05 截包与改包
        • 场景一:截断请求数据,然后篡改请求数据
        • 场景二:篡改返回的数据包
        • 场景三:截断请求数据,先篡改请求数据, 再篡改返回的数据包
        • 注意
      • 06 抓包时过滤指定请求

01 Fiddler 工具介绍

1. 下载与安装

下载地址:https://www.telerik.com/download/fiddler

2. Fiddler 工具界面介绍

图所示的是 Fiddler 工具的主界面。其中显示的是访问百度个人中心时捕获的数据,其结构大致分为 3 个区域。

  • 区域 1:标准的 Windows 程序菜单栏。
  • 区域 2:捕获的页面请求数据,以列表形式显示出请求数据的大概信息。
  • 区域 3:每个请求的详细信息。单击(区域 2)列表可展示相关数据。其分为上部和下部,上部是请求信息,下部是响应信息。

3. Fiddler 工具的工作原理

Fiddler 工具是一个中转站,也是代理服务,所以它才能获取请求和响应数据,如图所示。

02 手工调用 HTTP 接口

使用 Fiddler 工具可以进行单次的 HTTP 接口请求/响应数据分析。比如,有一个接口数据需要做测试。

  • 接口地址:https://www.gitlink.org.cn/api/projects.json?pinned=d&limit=20
  • 请求方式:GET

1. 发送HTTP请求

操作过程如图所示。

  1. 切换至工具的“Composer”选项卡(打开工具时默认打开该选项)。
  2. 选择请求方式。通过下拉列表中获取 GET 方式。
  3. 输入接口地址。因为是 GET 方式的,所以地址实际上是“URL+参数”的组合。
  4. 输入请求的消息报头。
  5. 单击“Execute”按钮,发送一次 HTTP 请求。
  6. 在图左侧列表中检查返回包的概要信息。在本例中,HTTP 返回码是 200
    (代表正常),HOST 是主机地址,URL 是接口地址段。
  7. 在最右侧也有一个列表,标题是 Log Requests,记录的是历史请求接口。双击
    列表中的数据,可以查看历史请求及其结果。

2. 查看返回数据包

操作过程如图所示:

  1. 双击图中左侧的请求列表数据。
  2. 在右侧选择“Inspectors”→“Headers”命令。
  3. 在下方看到本次接口请求方式、地址段及其参数。

 选择 JSON 的意思是“使用 JSON 格式展示返回数据包数据”,能看到并不是所有的返回包数据都是 JSON 格式的,对于非 JSON 格式的数据可以使用 TextView 模式来
查看。

03 获取 PC 端的网络数据包

该方法主要用来获取 PC 端设备的 HTTP 数据包。例如浏览器访问网站时,页面所调用的接口及其返回的数据包。
比如,打开一个陌生的网站,很想知道这个网站都和服务器做了哪些数据交互、都发送了哪些请求,甚至页面执行了某个操作后数据是怎么来的。

这里以GitLink平台登录页面(https://www.gitlink.org.cn/api/accounts/login.json)为例来介绍
具体步骤。
(1)打开 Fiddler 工具,确保工具左下角的“Capturing”处于开启状态。
(2)访问网站首页,输入登录账号、密码和验证码,单击“确定”按钮。
(3)观察 Fiddler 工具左侧区域,找到 Host 标题下对应的域名值(建议按 Host 排序
来筛选),如图所示。

(4)双击左侧的该条数据包概要,右侧展示的是具体请求数据和返回数据。

提示:
(1)左下角的“Capturing”标志:显示则表示开始监听和抓取数据,不显示则表示不监听和抓取(也就不显示数据包)。

(2)“All Processes”标志:监听 PC 端的所有网络请求。如果显示为 Web Browsers(Web 浏览器),则只监听 Web 浏览器发起的请求和返回数据;如果显示为 Non-Browser(非 Web 浏览器),则监听除 Web 浏览器外的所有其他进程;如显示为 Hide All(屏蔽所有),则不监听。
以上两个标志配合使用,可以很方便地控制监控时间和要监听的对象,避免其他无用数据的干扰。

04 获取手机端的网络数据包

既然 Fiddler 工具可以充当一个代理服务器的角色,自然可以作为手机上网的代理服务器。手机端发送的网络请求,会被代理服务器(Fiddler 工具)所捕获。这也正是 Fiddler工具能捕获到 APP 数据请求的原因。
配置代理的方法如下:

  1. 保证手机连接的 Wi-Fi 和 Fiddler 工具所在电脑处于同一个网段。
  2. 将 Fiddler 工具设置为支持移动端连接:
  • 选择菜单中的“Fiddler”→“Tools”→ “Options”命令。
  • 在打开的对话框中的“Connections”选项卡里勾选。“Allow remote computers to connect”复选框。
  • 设置“Fiddler listenson port”为“8888”,如图 所示。
  • 单击“OK”按钮关闭 Fiddler 工具。
  • 之后重新打开 Fiddler 工具。
  1. 运行对话框中输入cmd,在弹出的 DOS 窗口中执行netstat -anop tcp | findstr "LISTENING" | findstr ":8888"命令,以查看 Fiddler 工具进程是否能正常监听 8888 端口,如图所示。如果服务没有正常开启,则可以尝试使用其他端口。

  2. 在 DOS 命令窗口中里执行ipconfig命令,以查看本机 IP,如图所示。

  3. 设置手机网络代理

  • 打开手机连接的无线,将代理设置为手动
  • 将主机设为 10.47.38.127(运行 Fiddler 工具的电脑 IP)。
  • 将端口设为 8888(与 Fiddler 工具中设置的端口保持一致)。
  • 单击“确定”按钮(苹果手机直接后退即可)。
  1. 验证。在手机上访问 APP,或通过浏览器访问https://www.gitlink.org.cn/zone/tester首页,检查 Fiddler 工具左侧列表中是否有数据。

注意:

  • 测试完成后请记得关闭手机端代理设置。
  • 在做手机端抓包分析时,可以让 Fiddler 工具左下角的“Capturing”不显示,这样 Fiddle 只显示主动发起的请求,而不会截取手机端所有的请求包,可以减少不必要的数据。

05 截包与改包

在进行具体操作之前,要明确一件事情——为什么要做截包和改包,这对测试有什么帮助?

  1. 所谓“截包”,有两个层面的含义。
  • 截断请求数据包:即 Fiddler 工具截获页面的请求数据包,使其发送不到服务器端,只到 Fiddler 工具这一层就结束。
  • 截断返回数据包:即 Fiddler 工具拿到服务器端的返回数据包,但不返回给前端页面(即返回数据包被拦截),则请求方处于等待服务器端返回数据包的状态。这个可以用来模拟“等待服务器端返回数据包”和“服务器端返回数据包超时”情况,以测试前端页面如何处理。
  • “改包”的前提是“截包”,分为两种情况:1)修改请求数据包,再提交到服务器端,检查服务器端的处理情况;2)修改返回数据包,再提交给请求方,检查请求方的处理情况。它主要用在模拟“请求数据包或返回数据包不好被制造”的场景,比如,前端获取到的返回数据包中数据字段值超长时,页面是否会做截断处理(也可以修改数据库数据)。

场景一:截断请求数据,然后篡改请求数据

  1. 在 Fiddler 工具工作界面的左下角单击,出现如图所示红色的“T”标志,表示工具处于截断请求数据状态。

  2. 进行请求,成功捕获到请求,但是被拦截。

  3. 在 Fiddler 工具左侧列表中双击页面请求的接口,在右侧查看请求数据。

    • 修改请求数据,例如将password修改为test。
    • 然后单击 Fiddler工具工作界面右侧的Run to Completion
  4. 检查接口数据和页面显示的数据,如图所示。请求数据篡改成功。

场景二:篡改返回的数据包

  1. 在 Fiddler 工具工作界面的左下角双击,出现如图所示红色的 标志,表示工具处于截断返回数据包状态。

  2. 进行请求,成功捕获到请求,但是被拦截。

  • Fiddler 工具左侧列表中双击页面请求的接口,在右侧查看接口返回的数据。
  • 此时看到 Fiddler 工具已得到了接口返回的数据,但是前端的页面还没有显示,说明 Fiddler 工具成功地将接口返回数据拦截在工具中了。
  1. 在 TextView 模式下修改返回的数据,然后单击Fiddler 工具右侧的Run to Completion

  2. 检查接口数据和页面显示的数据。此时响应数据已经成功篡改。

场景三:截断请求数据,先篡改请求数据, 再篡改返回的数据包

该场景我将使用bpu命令方式。 bpu命令方式的优点在于仅影响指定URL,不会影响其他URL。 上述场景一,场景二的是影响所有URL的。

  1. 构造断点:输入bpu+空格+URL,回车

  2. 发送请求,进行抓包,成功捕获到指定的URL

  3. 双击被拦截的URL, 篡改请求参数,点击按钮Break on Response

  4. 点击按钮Break on Response后,会按照篡改后的请求参数,发送请求,获得响应数据,但是响应数据不返回。

  5. 在 TextView 模式下修改返回的数据,然后单击Fiddler 工具右侧的Run to Completion

  1. 请求响应成功。响应数据是被篡改的数据。

  1. 取消断点:输入bpu,回车

注意

当使用 Fiddler 篡改响应数据后无法正确返回的情况,可能是由于以下原因之一:

  1. 加密和验证:
  • 一些网站使用加密(HTTPS)或者数字签名等机制来保护其响应数据的完整性和安全性。
  • 如果网站启用了 SSL/TLS 或其他加密协议,并且使用了有效的证书,Fiddler 默认无法对其进行篡改或修改。
  • 在这种情况下,您可能需要进行额外的配置,以使Fiddler 可以透明地拦截和篡改加密流量。例如,可以通过安装 Fiddler 的根证书来实现。
  1. 服务器端验证:
  • 有些网站会在服务器端对请求和响应进行验证或检查,以确保数据的完整性和合法性。
  • 当您使用 Fiddler 篡改响应数据时,服务器可能会检测到异常或不一致的响应,从而拒绝返回正确的结果。
  • 这是一种安全措施,旨在防止恶意篡改和攻击。
  1. 前端脚本和逻辑:
  • 一些网站可能使用前端脚本(如 JavaScript)或其他逻辑来验证响应的完整性和有效性。
  • 当您篡改响应数据时,可能会破坏这些脚本和逻辑的预期行为,导致网站无法正确处理您的请求。

06 抓包时过滤指定请求

因为fiddler工具会抓取web端的所有请求,当我们操作指定平台时,有一些其他网页的请求也会被工具抓取到,不容易找到我们自己的操作请求。这个时候可以使用filters功能过滤指定的请求内容。操作方法:

  1. 点击Filters,选择Use Filters

  2. Hosts的第一个选项内容不用修改,第二个选项内容,选择为“Show only the following Hosts”

  3. 在下方输入我们想要过滤的域名或IP地址,以英文的分号间隔开。

  • 注意:还可以采用通配符的模式,例如:*.gitlink.org.cn
  1. 点击Actions应用生效,此后fiddler抓包的内容就是我们要求过滤的指定内容了。

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

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

相关文章

一键安装和卸载docker及docker-compose

代码: #!/bin/bashSYSTEMD_PATH/usr/lib/systemd/system/docker.service DOCKER_FILEdocker-20.10.23.tgz DOCKER_COMPOSE_FILEdocker-compose-plugin-2.15.1-3.el8.x86_64.rpm RED\E[1;31m GREEN\E[1;32m YELOW\E[1;33m SHAN\E[1;31;5m RES\E[0mfunction install_…

项目中期检查会议和进度对接

1.召开中期项目检查会议,与团队成员和博士王锟对接进度。对整体项目表示满意接受,指出重点需要修改提升和进一步开发完善的部分,以增强系统的完整度、功能亮点和界面数量点。具体为 ①注重“highlight”,即布局凸显主题功能&…

spring cloud 之 ribbon

Ribbon概念 Spring Cloud Ribbon 是基于 Netflix Ribbon 实现的一套客户端负载均衡的工具,主要功能是提供客户端负载均衡算法和服务调用。简单的说,就是在配置文件中列出 Load Balance( LB:将用户的请求平摊的分配到多个服务上&a…

JavaScript ES5中实现继承

1 对象和函数的原型 2 new、constructor 3 原型链的查找顺序 4 原型链实现的继承 5 借用构造函数继承 6 寄生组合实现继承 function 创建的名称如果开头是大写的,那这个创建的不是函数,是创建了类。 要注意区分!本章很多这样子的类。 实…

热烈祝贺! 爱创科技加入中经联溯源技术专业委员会!

6月27日,中国商业股份制企业经济联合会溯源技术专业委员会为北京爱创科技股份有限公司举行入会授牌仪式。授牌仪式由溯源技术专业委员会副秘书长卢要宁同志主持,溯源技术专业委员会主任宁晓鹏及北京爱创科技股份有限公司企业发展规划部总监杜薇出席。 在…

【网络安全带你练爬虫-100练】第3练:遍历获取到的列表中元素

目录 一、前言: 二、分析代码 三、完善代码 一、前言: (1)本练,我们来完善一下对于数据的处理 (2)对于同一标签内的内容的遍历爬取 上一段代码的,我们是不是在那个曾用名、高新…

库管理 + 表管理

REVIEW CREATE DROP DATABASE SELECT DATABASE(); SHOW DATABASES ;CREATE DATABASE IF NOT EXISTS GAMEDB ; DROP DATABASE IF EXISTS GAMEDB; CREATE SHOW ALTER TABLE 如何给表头重命名 CREATE TABLE student.studentinfo(name char(10), sex char(10), class char(5…

Redis的介绍和安装教程(配置文件)

1.Redis简单的介绍 redis是一种键值对的NoSql数据库,这里有两个关键字: 键值对 Nosql 其中键值型,是指Redis中存储的数据都是以key.value对的形式多种多样,可以实字符串、数值、甚至json,可以参考HashMap 然后NoSq…

[CSCCTF 2019 Qual] FlaskLight

打开链接,在注释里发现了参数名和请求方式 结合题目flask,检查是否存在SSTI模块注入: ?search{{7*7}} (如果对这类题不了解的建议先看我另一篇博客http://t.csdn.cn/4d812) 通过回显发现被执行了,存在S…

NacosConfig获取不到配置中心

<dependency><groupId>org.springframework.cloud</groupId><artifactId>spring-cloud-starter-bootstrap</artifactId><version>3.0.3</version></dependency> 版本说明 alibaba/spring-cloud-alibaba Wiki (github.com) …

【STM32智能车】小车状态

【STM32智能车】小车状态 搭建智能车 65MM轮径小车所选材料安装说明直行测试智能车可能存在的状态 智能车功能丰富&#xff0c;我们从最基础的开始&#xff0c;先来搭建一个智能车吧~。 搭建智能车 我们之前用了一个测试板子去学习调试电机&#xff0c;是时候拼装一个简单的车来…

CSS弹性盒子中弹性子元素文本超出弹性子元素宽或高后导致撑开弹性子元素原本宽或高的解决方法

当使用弹性布局时&#xff0c;设置父容器为弹性容器后&#xff0c;弹性子元素的文本内容超出宽或高后会撑开弹性子元素的原本应该显示的宽高&#xff0c;溢出父容器&#xff0c;只要设置弹性子元素的宽或高&#xff08;由父容器弹性排列方向决定&#xff09;的属性值为0即可解决…

echarts dataZoom.slider is used but not imported.

使用dataZoom时图表报错&#xff1a; resize should not be called during main process. omponent dataZoom.slider is used but not imported. 解决方法&#xff1a; 在使用的页面种单独引入一下dataZoom&#xff1a; import ‘echarts/lib/component/dataZoom’;

Redis【实战篇】---- Redis消息队列

Redis【实战篇】---- Redis消息队列 1. Redis消息队列 - 认识消息队列2. Redis消息队列 - 基于List实现消息队列3. Redis消息队列 - 基于PubSub的消息队列4. Redis消息队列 - 基于Stream的消息队列5. Redis消息队列 - 基于Stream的消息队列-消费组6. 基于Redis的Stream结构作为…

环肽抑制剂:1088715-84-7,LY2510924,LY2510924游离态,试剂相关特点说明

​编辑资料作者&#xff1a;陕西新研博美生物科技有限公司小编MISSwu​ LY2510924&#xff0c;LY2510924游离态&#xff0c;拮抗剂LY2510924&#xff0c;环肽&#xff0c;抑制剂 Product structure&#xff1a; Product specifications&#xff1a; 1.CAS No&#xff1a;10887…

机器学习基础之《特征工程(1)—数据集》

一、数据集 1、目标 知道数据集分为训练集和测试集 会使用sklearn的数据集 2、可用数据集 公司内部&#xff0c;比如百度、微博 数据接口&#xff0c;花钱 政府拥有的数据集 3、在学习阶段用到的数据集 scikit-learn特点&#xff1a; &#xff08;1&#xff09;数据量较小 &…

SpringBoot配置外部Tomcat项目启动流程源码分析

前言 SpringBoot应用默认以Jar包方式并且使用内置Servlet容器(默认Tomcat)&#xff0c;该种方式虽然简单但是默认不支持JSP并且优化容器比较复杂。故而我们可以使用习惯的外置Tomcat方式并将项目打War包。 【1】创建项目并打War包 ① 同样使用Spring Initializer方式创建项目 …

宝塔Panel搭建Python环境

服务器安装python环境 找到软件商店 应用搜索 输入&#xff1a;python 安装Python项目管理器2.4 开启首页显示 回到首页 找到python管理器并点击进入 安装对应的python版本 到这里 服务器就可以告一段落了 在本地开发服务端应用并上传服务器 将写好的python应用 导出依赖…

蓝桥杯专题-真题版含答案-【世纪末的星期】【猜年龄】【组素数】【第39级台阶】

点击跳转专栏>Unity3D特效百例点击跳转专栏>案例项目实战源码点击跳转专栏>游戏脚本-辅助自动化点击跳转专栏>Android控件全解手册点击跳转专栏>Scratch编程案例点击跳转>软考全系列点击跳转>蓝桥系列 &#x1f449;关于作者 专注于Android/Unity和各种游…

antv-x6在vue中使用:拖拽 Dnd、Stencil——以小诺管理平台为例

1、说明 由于antv-x6刚刚开放不久,一方面网上资料很少,此外antv目前官方的实例基本都是以react作为demo进行演示,所以vue的示例几乎没有,自己按照官方文档的react写了一个vue版本,仅供参考。 2、效果 先看一下demo的效果,如下所示 这是官方网文档的效果,同时官方也给…