Fiddler使用技巧

28 篇文章 0 订阅

1. Fiddler 是什么?

Fiddler是用C#编写的一个免费的HTTP/HTTPS网络调试器。英语中Fiddler是小提琴的意思,Fiddler Web Debugger就像小提琴一样,可以让前端开发变得更加优雅。

Fiddler是以代理服务器的方式,监听系统的网络数据流动。运行Fiddler后,就会在本地打开8888端口,网络数据流通过Fiddler进行中转时,我们可以监视HTTP/HTTPS数据流的记录,并加以分析,甚至还可以修改发送和接收的数据。Fiddler还提供了清除IE缓存、请求构造器、文本转换工具等等一系列工具,对前端开发工作很有价值。

2. 主要功能

  1. 分析页面性能
  2. 分析http请求/响应数据
  3. 设置断点,调试线上错误
  4. 伪造数据请求,调试数据接口

3. Fiddler的界面

fiddler

4. fiddler命令

常用命令:

  1. 选择类:?text、>size、<size、=status、@host、
  2. blod text、select、allbut、keeponly
  3. 断点类:bpafter、bps、bpv、bpm、bpu
  4. 控制类:hide、start、stop、show、quit
  5. 其他:cls/clear、dump、g/go、help、urlreplace

fiddler

5.使用fiddler进行数据分析

fiddler

6.代码查看器-双击session(需下载插件,见后面)

fiddler 
利用查看器提供的很多形式,我们可以查看数据流的内容。

7.请求构建器(Request Builder)

fiddler 
可以创建任意数据的请求,如上,输入url后点击Execute按钮

8.过滤器

fiddler 
过滤器可以对左侧的数据流列表进行过滤,我们可以标记、修改或隐藏某些特征的数据流。如上图,通过过滤只展现host为p.baidu.com的请求

9.AutoResponse功能

fiddler 
这个功能可以算的上是Fiddler最实用的功能,可以让我们修改服务器端返回的数据,例如让返回都是HTTP404或者读取本地文件作为返回内容。我们将在实例中介绍利用AutoResponse功能。

10.文本编码和解码

开启Tools -> Text Encode/Decode,支持编码:

  1. Base64编码解码
  2. URL Encode/Decode
  3. 十六进制编码
  4. Unicode编码解码
  5. HTML实体化编码解码
  6. UTF-7编码解码
  7. Deflated 编码解码

fiddler 
提供了常用的一些文本编解码的转换。

11.模拟user-agent

在做mobile上的网页开发时,经常需要修改user-agents为iphone,如下图 
fiddler 
而通过fiddler可以直接修改所有请求的user-agents,这样很方便,默认没有iphone的user-agents,需要自己修改配置——可以编辑fiddler Rules来增加和变更(Rules->Customize Rules

12.模拟慢速网络

fiddler

13.对两个数据流进行比较

fiddler

14.Fiddler提供加载时间瀑布图

fiddler

15.Fiddler扩展插件安装

  1. 代码高亮插件 http://www.fiddler2.com/redir/?id=SYNTAXVIEWINSTALL

fiddler

  1. javascript代码格式化插件 http://www.fiddler2.com/dl/FiddlerJSFormatSetup.exe安装完毕后,在任何一条js请求后点击右键,选择Make Javascript Pretty
  2. Gallery http://www.fiddler2.com/dl/FiddlerGallerySetup.exe展现图片

更多插件可以到官网下载。 
Fiddler插件官网下载:
http://www.fiddler2.com/fiddler2/extensions.asp

 

16.Fiddler的扩展机制

Fiddler 支持 Jscript.NET 引擎,可以很方便的修改 CustomRules.js 来扩展。修改后立即生效,开启:Rules -> Customize Rules… 
Handles类两个最重要的事件:

  1. OnBeforeRequest(oSession: Session)
  2. OnBeforeResponse(oSession: Session)

OnBeforeRequest范例

fiddler 
通过上面代码,可以将js和css的session分别标示为红色和绿色,效果如下:

fiddler

17.为啥有时捕获不到:

  1. 手动修改浏览器代理ip地址为:127.0.0.1:8888
  2. 检查fiddler捕获开关

fiddler

  1. 检查过滤器设置(filters)

fiddler

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值