认识Fiddler

时间:2021-09-26 03:52:18

一、Fiddler界面介绍。(注:下图中的功能区面板显示的是“Inspectors”的选项卡界面)

  认识Fiddler

二、工具栏介绍。

  认识Fiddler

  1、认识Fiddler气泡:备注。添加之后在会话栏的Comment列中显示备注内容。

  2、认识FiddlerReplay:回放,经常使用。重播一个会话。快捷键:”选中会话+R”。

  3、认识Fiddler删除会话,用于过滤和清除请求。

  4、认识Fiddler断点调式。配合状态栏上的断点工具。功能类似Debug。

  5、Stream:代理模式。默认:缓冲模式。点击进行切换。

  6、Decode:解压请求。解压http请求里面的东西,帮助查看。

  7、认识FiddlerKeep:指示fiddler的保持会话数目。

  8、Any Process:捕获请求,只看需要的请求。将“靶心”投向需要的请求。

  9、Find:查找请求。用颜色标注查找的请求。

  10、Save:保存会话。

  11、认识Fiddler截图:默认5秒后截图。

  12、认识Fiddler计时器:第一次点击-开始计时;第二次点击–返回计时结果;第三次点击-清零,重新计时。右键点击—不计时。

  13、Browse:启动浏览器。

  14、Clear Cache:清空缓存。

  15、TextWizard:经常使用,展示编码、解码文本内容。

  16、Tearoff:浮窗,也就是将会话栏和功能面板分离为两个窗口(如下图所示),将前面的功能面板关闭即可合并。

    认识Fiddler

三、会话栏介绍。

  认识Fiddler

各列含义:

1、[#]—— Http Request的顺序,从1开始,按照页面加载请求的顺序递增,点击可以重新排序。
2、[ Resuit]——HP响应的状态,可以参考这里。
3、[ Protocol]——请求使用的协议(如HTp/HTPs/FTP)。
4、[Host]——请求地址的域名。
5、[URL]——请求的服务器路径和文件名,也包括GET参数。
6、[BODY]——请求的大小,以byte为单位。
7、[ Caching]——请求的缓存过期时间或缓存控制 header等值。
8、[Content-Type]——请求响应的类型( Content-Type)。
9、[ Process]——发出此请求的 Windows进程及进程ID。
10、[ Comments]——用户通过脚本或者右键菜单给此 session增加的备注。
11、[ Custom]——用户可以通过脚本设置的自定义值。

  其中  [#]  栏中的图片标识的含义:

    认识Fiddler

  会话栏中显示的列可以自定义:

    1、添加(右键);2、隐藏/显示(右键);3、拖动排序;

  比如添加一个请求方法的列,可以如下操作:在会话栏列名处右键后,选择“Customize columns...”选项,然后在弹窗中选择“Miscellaneous”和“RequestMethod”,点击“Add”后在列名中可以看到RequestMethod。

    认识Fiddler

    认识Fiddler

三、功能面板的选项卡介绍。

 认识Fiddler

  

  1、Statistics选项卡:显示HTTP请求的性能和其他数据。

      认识Fiddler

  2、Inspectors选项卡:提供headers、textview、hexview,Raw等多种方式查看单条http请求的请求报文的信息,分为上下两个部分,上半部分是请求部分,下半部分是响应部分。对于每一部分,都各自提供了多种不同格式以查看每个请求和响应的内容。

  3、AutoResponder选项卡是Fiddler比较重要且比较强大的功能之一。可用于拦截某一请求,并重定向到本地的资源,或者使用Fiddler的内置响应。可用于调试服务器端代码而无需修改服务器端的代码和配置,因为拦截和重定向后,实际*问的是本地的文件或者得到的是Fiddler的内置响应。

  4、composer选项卡,用于前后端链接调试,可以模拟向相应的服务器发送数据的过程(不错,这就是灌水机器人的基本原理,也可以是部分http flood的一种方式)。

  5、Filter选项卡,可以设置Fiddler的过滤规则,来达到过滤http请求的目的。最简单如:过滤内网http请求而只抓取internet的http请求,或则过滤相应域名的http请求。Fiddler的过滤器非常强大,可以过滤特定http状态码的请求,可以过滤特定请求类型的http请求(如css请求,image请求,js请求等),可以过滤请求报文大于或则小于指定大小(byte)的请求。

  6、Timeline选项卡:用于 性能分析。对选择多个请求有意义。作用类似HttpWatch。

四、命令栏介绍。

  常见的命令有:

    • 全局命令===============================================================
    • help命令: 打开官方的使用页面介绍,所有的命令都会列出来 。
    • hide命令:隐藏Fiddler界面,系统后台运行
    • quit命令:退出Fiddler
    • show命令:将Fiddler从系统托盘中恢复,从ExecAction.exe获取更多有用的触发规则
    • start命令:注册成为系统代理,开始监听请求
    • stop命令:取消注册为系统代理,停止监听请求
    • cls 或者clear命令: 清屏 (Ctrl+x 也可以清屏)
    • dump命令:打包所有会话成zip归档文件并转存在C:\
    • urlreplace命令:以一个不同的字符串替换URL中任何字符串。设置此命令将清除该命令的任何以前的值,不带参数调用它将取消更换,注:1、urlreplace SeekStr ReplaceWithStr;2、urlreplace //取消设置
    • 筛选命令================================================================
    • allbut 或者 keeponly命令:隐藏掉Content-Type头中除了包含指定字符串的所有会话,用于筛选,注:1、allbut html;2、allbut java
    • select 命令:选择某种类型的响应,例如,输入 select image(还有css类型、html类型等)
    • @host命令:选择会话中域名包含host的会话,此时按Enter键可高亮所有匹配的结果,如:@baidu.com //选择 www.baidu.com, map.baidu.com, 等等
    • ?命令,例如“?.png” 用来选择png后缀的图片,“?qq”将选中host中含有“qq”字样的包并蓝色底标色
    • =status命令、 =method命令,例如:输入“=post”将选择post的数据包并用蓝色底标色,输入“=502”将选择result是502的数据包并用蓝色底标色
    • size >或者size < 命令:size>40000  //选择大小超过40kb的响应;  size<5k  //选择小于5kb的响应
    • bold 命令:对带有某个字段的请求包字体加粗,取消加粗再次输入bold敲回车即可。如“bold baidu”  可以将百度的包加粗显示
    • !dns hostname命令:进行目标域名的DNS查找,并将结果显示在LOG选项卡上,注:1、!dns www.baidu.com;2、!nslookup www.baidu.com)3Z~5L`[P${H(9G_DQV7_MS
    • !listen PORT [CERTHOSTNAME]命令:在另一个端口增设一个监听器,选择安全的HTTPS证书。注:1、!listen 8889;2、!listen 4443 localhost;3、!listen  444 secure.example.com
    • 断点命令===============================================================
    • bpu 命令:对包含指定字符串的URI创建请求断点。设置此命令将清除该命令的任何以前的值,不带参数调用它会禁用断点,注:1、bpu /index.php;2、bpu //取消设置
    • bpm 或者 bpv命令:对指定的HTTP方法创建请求断点。设置此命令将清除该命令的任何以前的值,不带参数调用它会禁用断点,注:1、bpm POST;2、bpv //取消设置
    • bpafter命令:中断RequestURI中包含指定字符串的任何响应,取消再次输入bpafter敲回车即可。例如:1、bpafter /favicon.ico;2、bpafter //取消设置
    • bps命令:中断与选择的状态代码匹配的响应,取消再次输入bps敲回车即可。例如:1、bps 404;2、bps //取消设置
    • g 或者 go命令:恢复所有设置断点的会话
    • ======================================================================   认识Fiddler

五、状态栏介绍。

  认识Fiddler

1、Capturing:开启/关闭 fiddler的监听;

2、All Processes:过滤会话选择;

六、操作会话。

  1、会话搜索,标记颜色;(注意汉字或者特殊字符可能查询不到,因为在HTTP请求中,汉字或者特殊字符被转义了)

    认识Fiddler

    也可以使用工具栏中的“查找”按钮来执行会话搜索的操作。

    认识Fiddler

2、会话过滤;

  Filter标签则可以设置Fiddler的过滤规则,来达到过滤http请求的目的。最简单如:过滤内网http请求而只抓取internet的http请求,或则过滤相应域名的http请求。Fiddler的过滤器非常强大,可以过滤特定http状态码的请求,可以过滤特定请求类型的http请求(如css请求,image请求,js请求等),可以过滤请求报文大于或则小于指定大小(byte)的请求。

  认识Fiddler

3、会话筛选(父子关系和同类型)

  认识Fiddler

4、标记会话;

  选中会话,右键,选择  “Mark > 标记方式”  选项即可实现。效果图如下:

  认识Fiddler

5、会话编辑和保存;

  认识Fiddler

  认识Fiddler

6、会话删除;

  认识Fiddler

  认识Fiddler

7、会话比较(比较两个会话的不同之处)。

    < 需要用到fiddler的插件windiff,要先下载该插件,设置后即可使用。>

  认识Fiddler

    认识Fiddler

    认识Fiddler

四、设置断点——修改报文。

  1、断点类型:

  (a)全局断点:工具栏Rules > Automatic Breakpoints > Before Requests .

    认识Fiddler

  (b)单个断点:针对单一会话拦截,方法是在命令行输入命令

    (修改请求报文使用命令“bpu + 拦截目标URL或者字符串”;修改响应报文使用命令“bpafter +拦截目标URL或者字符串”)

  2、修改报文:

  (a)修改请求报文;

    认识Fiddler

  (b)伪造http响应:在上面的步骤三中更改点击“choose response...”按钮,选择想要设置的放回状态码即可。

  (c)修改响应报文;

  (d)伪造Referer。(题外话:什么是HTTP Referer,简言之,HTTP Referer是header的一部分,当浏览器向web服务器发送请求的时候,一般会带上Referer,告诉服务器我是从哪个页面链接过来的,服务器 籍此可以获得一些信息用于处理。比如从我主页上链接到一个朋友那里,他的服务器就能够从HTTP Referer中统计出每天有多少用户点击我主页上的链接访问他的网站。虽然Referer并不可靠,但用来防止图片盗链还是足够的。Referer其实应该是英文单词Referrer,不过拼错的人太多了,所以编写标准的人也就将错就错了。 )

  (e)模拟网络超时:fiddler设置断点后就拦截住客户端发出的请求,这样就相当于网络超时。目的是为了再检查客户端有没有重发或者超时后的机制。方法如下图:

    认识Fiddler

  (f)精确控制网速(需要修改fiddler的脚本)

五、Fiddler的其他插件应用。

  1、JavaScript Formatter;

  2、Gallery