Fiddler 功能模块详解

什么是Fiddler?

官方说法:记录您的计算机和因特网之间的所有HTTP(S)流量。检查流量,设置断点,并处理请求/响应。

通俗说法:Fiddler是一个http协议调试代理工具,Fiddler4数据抓包软件能够记录并检查所有你的电脑和互联网之间的http通讯,设置断点,查看所有的“进出”Fiddler的数据(指cookie,html,js,css等文件,)

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

功能说明:

一、菜单栏

  1. File
image.png
  • Capture Traffic:默认勾选,勾选此项才可抓包,与点击左下角状态栏的 Capture 效果一样

  • New Viewer:开启一个新的 fiddler 的 viewer,注意这里不是再开一个新的 fiddler,而是开一个新的fiddler的viewer

  • Load Archive…:用于重新加载之前捕获到的 SAZ 文件格式保存的流量。Session Archive Zip 文件,用于保存 http 请求信息。

  • Recent Archives:查看最近之前捕获到的 SAZ 文件格式保存的流量

  • Save:保存

  • Import Sessions…:从目标文件夹及其子文件夹加载所有 SAZ 文件。缓存和重用密码。 支持导入从其他工具获得的流量

  • Export sessions:支持用fiddler把捕捉到的 sesison 用多种方式保存。CURL 脚本由 CURL 回放;参见 CURL

  • Exit:退出 Fiddler

  1. Edit
    image.png
  • Copy:用来拷贝请求的相关信息。有用于复制在 web session 列表中选中的 session 信息,包括 just URL(选中的 session 的 URL 复制到剪切板中)、this column(拷贝菜单所在列的文本)、terse summary(选中 session 的简要说明复制到剪切板里)、header only (把 session 请求头复制到剪切板里)、session(把整个的 session 列表都复制到剪切板里)、full summary(把列表中显示的所有 session 信息复制到剪切板里)这些功能

  • Remove:主要是用来移除左侧边栏中的 session

  • Select All:全选左侧边栏中 session

  • Undelete:恢复之前删除的 session

  • Paste as Sessions:把剪切板里的 sesisongs 复制到 web sessions 中,把以前的会话粘贴回来

  • Mark:自定义不同 session 的显示颜色

  • Unlock for Editing:把锁定的 session 进行解锁,可以进行编辑,默认情况下是不可进行编辑的,默认可以看到选定的 session 前是“锁”的图形 ,点击此按钮后变成可编辑按钮 。

  • Find Sessions…:搜索 session

  1. Rules
image.png
  • Hide Image Requests:可以隐藏图片请求,让图片类的 session 不在 session 框中显示出来

  • Hide CONNECTs:可以隐藏 CONNECT 方法的请求,让这类 session 不在 session 框中显示出来

  • Automatic Breakpoints:自动断点,控制是否自动在 Before Request 或 After Request 处断点,来修改请求或响应的内容

  • Customize Rules…:来打开 fiddler script 工具,调取脚本操作,多用于网络修改,其他自定义时使用

  • Require proxy authentication:若选中此项,则所有未提交 Require proxy authentication 的请求头的请求会返回 HTTP/407 响应,要求客户安装证书

  • Apply GZIP Encoding:请求 GZIP 编码,若选中此项,则只要请求包含了 gzip 标识的 Accept-Encoding 请求头就会对除了图片以外的所有相应使用 GZIP HTTP 进行压缩

  • Remove All Encoding:若选中此项,会删除所有请求相应的 http 内容编码和传输编码

  • Hide 304s:在session框中隐藏所有的 304 的 session

  • Request Japanese Content:把所有的 Accept-Encoding 请求头设置替换成 ja 标示,标示客户端希望以日语的形式发送

  • Automatically Authenticate:自动进行身份验证 鉴权

  • User-Agents:选择相应的用户代理模式,默认是选择 disabled。那什么是 user-agent 呢?ua 是头域的组成部分,简单来说就是你向访问的网站提供你所用的浏览器的类型等信息,ua 字符串在每次浏览器 http 请求时发送到服务器端

  • Performance:此项提供影响 web 性能的简单选项。若选中了 simulate modem speeds,它会设置所有后续 session 的 flag,把 request-trickle-delay 标志设置为 300,所有上传数据延迟 300ms/kb,若把 response-trickle-delay 标志位设为 150,会使所有下载数据延迟 150ms/kb。若选中了 disable caching,将会删除所有 If-None-Match和If-Modified-Since 请求头,并添加 Pragma:no-cache 请求头,选中该项还会删除响应中的所有 Expires 头,并把 Cache-Control 响应头设置成 no-cache,该项无法阻止浏览器重用在所用该选项之前所缓存的响应,在选中该选项后,为了得到最佳结果,最好是清空浏览器中缓存。若选择 Catch Always Fresh 会自动响应所有包含 http/304 响应的有条件的 http 请求,表示客户端缓存是最新的,当访问的站点无法正确的设置缓存失效日期时,该选项可以极大的提高性能。

  1. Tools
    image.png
  • Options…:打开 Options 窗口,是 fiddler 抓包的一些设置项,包括对抓取接口是 Http 还是 Https 的设置,获取证书,设置代理端口号等功能

  • WinINET Options…:打开IE浏览器的 options 进行设置

  • Clear WinINET Catch:清空 IE 和其他应用中所使用的 WinINET 的缓存文件

  • Clear WinINET Cookies:清空 IE 和其他应用中所使用的 WinINET 的 Cookies 文件

  • TextWizard:文本向导工具,是一个非常好用的可以轻松将 text 文本 encode 和 decode 的小工具

  • Reset Script:重置脚本

  • Sandbox:fiddler sanbox 官方文档

  • View IE Cache:查看IE浏览器缓存文件夹

  • New Session Clipboard…:打开一个新的 session 剪贴板,可以把侧边栏中的 session 拖到这个剪贴板中具体来查看

  • HOSTS:主机重定向工具。若在其中勾选 Enable 框,然后在下面加入 host 配置,点击保存之后,这个配置并不会修改到本地 hosts 中,取消勾选就会失效,若点击 Import Windows Hosts File 将会导入本地的 host 文件内容、

  1. View
    image.png
  • Show Toolbar:显示工具栏,默认是勾选的

  • Default Layout:默认 layout,session 在左,请求和响应在右边的上下处

  • Stacked Layout:session 在上,请求在下方

  • Wide layout:session 在上,请求和响应在下方的左右处

  • Tabs:打开标签页面,其中有三个标签可以打开,分别是 Preferences(fiddler 偏好属性),AutoSave(fiddler 自动保存的设置),APITest(api 的测试)

  • Statistics:查看一个请求的统计数据

  • Inspectors:嗅探,用来查看会话的内容,上面是请求,下面是响应

  • Composer:设计构造,在 Composer 中进行请求的修改,可以把 session 框中的数据先清除,然后点击 Composer 中的 Excute 按钮来发送请求,请求出现在 session 框中

  • Minimize To Tray:最小化托盘

  • Squish Session List:挤压 session 框

  • AutoScroll Session List:自动滚动会话列表,默认是勾选此项的,勾选此项后,session 框中的每出现新的 session,session 框中就会不断向下滚动,若不勾选此项,就很方便具体某一个 session 的定位,即使出现了新的 session 也不会自动向下滚动

  • Refresh:刷新功能,按 F5 刷新

  1. Help
  • Help:进入 fiddler 的帮助的网页中

  • Get Fiddler Book…:fiddler book 的网页

  • Discussions:fiddler 的讨论网页,这个需要魔法上网

  • Http Preferences:进入 http preferences 相关网站

  • Troubleshoot…:会捕获所有请求,对于哪些被过滤的请求用删除线表示出来并给出原因,使用时候会打开一个网页

  • Get Priority Support…:打开网页购买 fiddler 的优先级服务

  • Check for Updates…:检查软件更新情况

  • Send Feedback…:意见反馈

  • About:当前 fiddler 的相关信息

二、工具栏

image.png
  • WinConfig windows 使用了一种叫做“AppContainer”的隔离技术,使得一些流量无法正常捕获,在 fiddler 中点击 WinConfig 按钮可以解除这个诅咒,这个与菜单栏 Tools→Win8 Loopback Exemptions 功能是一致的

  • image.png

    此按钮来给选定的 session 添加注释

  • Replay 重发按钮,选定请求重发按钮

  • image.png
  • 移除按钮,其中有 Remove all 移除所有,Images,CONNECTs,Non-200s,Non-Browser,Complete & Unmarked,Duplicate response bodies,这些都是移除 session 中的这些状态的选项

  • Go 重跑 sessions,依据断点暂停

  • Stream流模式是一种实时通信模式,请求之后实时的返回,更接近浏览器真实行为,但 fiddler 默认是缓冲模式而不是流模式

  • Decode 解码,这里可以将 session 中乱码进行解码方便查看

  • Keep All sessions All sessions:这里可以保持 session 框中存在多少个 sessions

  • Any Process 点击此按钮并且拖动到你想要捕获的浏览器从而实现只捕获某个浏览器的请求

  • Find 查询

  • Save 保存按钮,保存所有的 session 成 SAZ 文件

  • image.png

    截图

  • image.png

    计时功能 手动点击运行,手动点击暂停终止

  • Browser 打开浏览器来查看响应数据

  • Clear Cache 清除 WinINET 的缓存,按住 CTRL 键点击可以清除已经存在的 cookies

  • TextWizard 此工具可以将某一编码过的或者未编码过的字串拿到此处解码和编码,在菜单栏中的 Tools 中也有此项可以打开

  • Tearoff 此功能用来将右边栏里的请求和响应部分给单独拆成一个新窗口,方便视察

  • MSDN Search… 在网页版的微软开发中去搜索

  • image.png

    帮助

  • image.png

    鼠标悬停显示本机的一些ip信息

  • image.png

    用来关闭工具栏的按钮,在 View 中选择第一个可以打开工具栏

三、底端状态栏

image.png
  • image.png

    此处与菜单栏中 File→Capture Traffic 效果是一致的,默认底端状态栏此处是有 Caturing,有它才表示 fiddler 捕获请求

  • All Processes 这里有 All Processes,Web Browsers,Non-Browser,Hide All 几个选项,这个几个选项顾名思义,但要注意的是这些不是筛选当前 session 框中的 session,而是选中需要筛选的状态之后,后面的请求会按照此状态来筛选

  • 数字/数字 第一个数字表示这一个请求,第二个数字表示 session 框中共有多少 session

  • image.png

    此处显示请求的 url 网址

三、Request 栏

在 request 栏中有 9 个大的标签页,分别是 Inspector,AutoResponder,Composer,Fiddler Orchestra Beta,Fiddler Script,Log,Filters,Timeline,Statistics

  • 这里是查看某个 session 的请求和响应,响应的话专门置为一栏讲解,请求的话又可分为 10 个小的标签页。并且右键点击这 10 个标签页可以查看 Inspector的属性还有诸如 copy as image 和隐藏标签页的功能

  • headers

    :这里是请求头中的信息,包括 cache,cookies 等信息,点击右边黄色的 Raw 可以以新窗口的形式来显示原生头信息,而 Header Definitions 可以查看 fiddler 官方的头信息的网页版帮助文档,可能需要魔法上网

  • textview

    TextView 方式显示传送过去的请求体数据

  • syntaxview

    SyntaxView 方式显示传送过去的请求体数据

  • webforms

    网页表单方式显示传送过去的请求体数据

  • hexview

    十六进制视图的方式显示传过去的数据

  • auth

    显示请求中的身份认证信息

  • cookies

    显示该请求的cookies信息

  • raw

    显示该原生的请求体

  • json

    json 显示请求

  • xml

    xml 显示请求

  • autoresponder

    重定向,本机代替服务器发送响应

  • composer

    Composer 和 Inspector 都可以篡改数据,Inspector是篡改输入的数据,但是 Composer 却可以篡改 Cookies 中的数据,并通过 Execute 发送重新篡改后的请求,界面上的控件比较简单
    composer
  • Fiddler Orchestra Beta

    这个功能应该还是 beta 测试阶段,暂未开放

  • FiddlerScript
    fiddler 在 Web 前端开发时候经常使用,用户再修改请求头信息时候经常需要设置断点,但是设置后会在断点处停下,之后点击重启才行,而 fiddler script 本质是 JScript.NET 语言写的脚本文件 CustomRules.js,语法类似 C#,若果是修改 CustomRules.js 其实可以很容易的修改 http 的请求的应答,不用中断程序,还可以针对不同 URI 做特殊处理,甚至可以根据开发者的需要去定制菜单,功能可以说是非常强大的。脚本文件 CustomRules.js 位于 C:\Documents and Settings[your user]\My Documents\Fiddler2\Scripts\CustomRules.js 下,你也可以在 Fiddler 中打开 CustomRules.js 文件, 启动 Fiddler, 点击菜单 Rules->Customize Rules。Fiddler Script 的官方帮助文档的地址是:FiddlerScript 官方帮助文档。可以直接编辑 CustomRules.js 文件,也可以下载 Fiddler Script Editor 来编辑,下载的地址是 Fiddler Script Editor 下载网址。Fiddler Script Editor 提供了语法高亮,以及智能提示的功能,方便编辑。
    fiddler script editor

  • log

    查看 fiddler 的 event log 信息,不同请求的 log 信息应该是一致的,每当更新一次页面,event log 会自动刷新一次,若将上方的 any process 拖动到指定浏览器后,fiddler 会单独记录该浏览器页面的通信信息

  • Filters

    这个可以用来过滤 session 中的请求

  • Timeline

    可以查看请求响应的时间轴
    Timeline
  • Statistics

    里头包含该 session 请求的统计数据,包括请求次数,请求与响应字节数,信息头和体各有多少字节,以及连接时间点,响应信息类型,最后,下面有个全球性能估计的数据:
    statistics

四、Response 栏

这里包含 13 个小的标签页面,分别是 Transformer,Header,TextView,SyntaxView,ImageView,HexView,WebView,Auth,Caching,Cookies,Raw,JSON,XML
response
  • Transformer:这里显示了响应体的字节数,这里头的 Chunked Transfer-Encoding 和 HTTP Compression 是分块传输编码和 HTTP 压缩技术,这就需要 http 的知识了
    Transformer
  • Headers:这里可以看到响应头部分,包括 http 的协议,返回状态码,连接情况等
    重定向,本机代替服务器发送响应响应体信息

  • SyntaxView:这里返回 SyntaxView 形式的响应体信息

  • ImageView:如果是返回图片的话这里将有显示,并且左边会显示图片的信息

  • HexView:这里会显示响应体的十六进制信息

  • WebView:这里会用网页的形式来显示响应体的信息

  • Auth:显示身份验证

  • Caching:显示缓存信息

  • Cookies:显示 Cookies 信息

  • Raw:显示原生的响应信息

  • JSON:响应体中的数据 json 显示

  • XML:响应体中的数据 XML 显示

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 214,029评论 6 493
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,238评论 3 388
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 159,576评论 0 349
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,214评论 1 287
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,324评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,392评论 1 292
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,416评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,196评论 0 269
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,631评论 1 306
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,919评论 2 328
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,090评论 1 342
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,767评论 4 337
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,410评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,090评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,328评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,952评论 2 365
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,979评论 2 351