`
iavere
  • 浏览: 11065 次
  • 性别: Icon_minigender_1
  • 来自: 武汉
社区版块
存档分类
最新评论

Fiddler工具使用说明 .

 
阅读更多
第一部分 工具介绍
这个工具我已经使用比较长时间了,对我的帮助也挺大,今天我翻译的微软的文章,让更多的朋友都来了解这个不错的工具,也是我第一次翻译文章,不恰当之处请大家大家多多指正。
介绍:

你是不是曾经疑惑过你的web程序和IE是如何交互的?你是不是遇到过一些奇怪的而你又无法解决的性能瓶颈?你是不是对那些发送给服务器端的cookie 和那些你下载下来的被标记为可缓存的内容感到好奇?

Fiddler官方网站及下载地址:http://www.fiddlertool.com/Fiddler/dev/

微软的Fiddler能够帮助你回答以上的问题,不但如此,它还是一个http调试代理,它能够记录所有的你电脑和互联网之间的http通讯,Fiddler 可以也可以让你检查所有的http通讯,设置断点,以及Fiddle 所有的“进出”的数据(指cookie,html,js,css等文件,这些都可以让你胡乱修改的意思)。 Fiddler  要比其他的网络调试器要更加简单,因为它仅仅暴露http通讯还有提供一个用户友好的格式。

Fiddler 包含一个简单却功能强大的基于JScript .NET 事件脚本子系统,他非常灵活性非常棒,可以支持众多的http调试任务。Fiddler 是用C#写出来的。

。。。。。接下来是一大段废话,关于如何安装的,只要一路next,就可以了。这段话我就跳过,直接切入正题了。

Running Fiddler

当你启动了Fiddler,程序将会把自己作为一个微软互联网服务的系统代理中去。你可以通过检查代理设置对话框来验证Fiddler是被正确地截取了web请求。操作是这样的:点击IE设置,工具,局域网设置,最后点击高级。

作为系统代理,所有的来自微软互联网服务(WinInet)的http请求再到达目标Web服务器的之前都会经过Fiddle,同样的,所有的Http响应都会在返回客户端之前流经Fiddler。这样,就能明白Fiddler很多作用了吧!




当你关闭Fiddler的时候,它就会自动从系统注册表中移出,换句话说,当你关闭了Fiddler后,不会占着茅坑不拉屎。


下面,是一个Fillder的用户界面,大家可以参考参考其功能。





用Fiddler来做性能测试
HTTP统计视图
通过显示所有的Http通讯,Fiddler可以轻松的演示哪些用来生成一个页面,通过统计页面(就是Fiddler左边的那个大框)用户可以很轻松的使用多选,来得到一个WEB页面的“总重量”(页面文件以及相关js,css等)你也可以很轻松得看到你请求的某个页面,总共请求了多少次,以及多少字节被转化了。






另外,通过暴露HTTP头,用户可以看见哪些页面被允许在客户端或者是代理端进行缓存。如果要是一个响应没有包含Cache-Control 头,那么他就不会被缓存在客户端。










用Fiddler来调试


Fiddler支持断点调试概念,当你在软件的菜单—rules—automatic breakpoints选项选择beforerequest,或者当这些请求或响应属性能够跟目标的标准相匹配,Fiddler就能够暂停Http通讯,情切允许修改请求和响应。这种功能对于安全测试是非常有用的,当然也可以用来做一般的功能测试,因为所有的代码路径都可以用来演习。



Session检查
用户可以在BuilderPage项种来以手工的方式来创建一个HTTP请求(即在Fiddler右侧的tab的第三个,RequestBUILDER),或者可以使用拖拽操作从Session列表中来移动一个已经存在的请求到builder page 来再次执行这个请求。。。


Fiddler 扩展
Fiddler可以使用 .net framework来对它进行扩展。有2种为Fiddler扩展准备的基本机制:

自定义规则,和规则检查。

使用脚本化的规则来扩展Fiddler


Fiddler支持JScript .NET引擎,它可以允许用户自动地修改Http请求和响应。这个引擎能够在可视化界面修改在FiddlerUI中的Session,可以从列表中提取你感兴趣的错误,也可以移除你不感兴趣的Session。


以下的示例代码演示当cookie被加载的时候把界面变成紫色。

static function OnBeforeRequest(oSession:Fiddler.Session){   if (oSession.oRequest.headers.Exists("Cookie")){      oSession["ui-color"] = "purple";      oSession["ui-bold"] = "cookie";   }}
通过加入Inspectors来扩展Fiddler
用户可以加入一个Inspector插件对象,来使用.net下的任何语言来编写Fiddler扩展。RequestInspectors 和 ResponseInspectors提供一个格式规范的,或者是被指定的(用户自定义)Http请求和响应视图。

默认安装中,Fiddler加入了一下的Inspectors:

Request Inspectors

[RW] Headers—Shows request headers and status.

[RW] TextView—Shows the request body in a text box. (原始的请求body视图)

[RW] HexView—Shows the request body in a hexadecimal view. (body的16进制视图)

[RO] XML—Shows the request body as an XML DOM in a tree view.(以XML方式展示请求)


Response Inspectors

[RW] Transformer—Removes GZip, DEFLATE, and CHUNKED encodings for easier debugging.

[RW] Headers—Shows response headers and status.

[RW] TextView—Shows the response body in a text box.

[RW] HexView—Shows the response body in a hexadecimal view. (16进制视图)

[RO] ImageView—Shows the response body as an Image. Supports all .NET image formats.

[RO] XML—Shows the response body as an XML DOM in a tree view.

[RO] Privacy—Explains the P3P statement in the response headers, if present.(如果在响应头中有关于隐私策略的说明就展示出来)

第二部分 用 Fiddler 看看 UpdatePanel 发生了什么
实验步骤

启动 Fiddler,访问我们事先写好的 UpdatePanel 网页(注意不要用 127.0.0.1 或 localhost)。

依次点击 btnIn、btnInToOut、btnOut、btnOutToIn 这四个按钮。

结果观察

在 Fiddler 中,我们可以得到五个会话,第一个是打开网页时产生的,后面四个是点击按钮时产生的。

•我们在会话列表中可以看到第二、三个会话的图标是文本文件,同时拉宽列表,可以看到 Content-Type 为 text/plain,Body 只有几百字节。
•而第四、五个会话的图标是网页,同时拉宽列表,可以看到 Content-Type 为 text/html,Body 有几千字节。
这说明在 UpdatePanel 中的按钮,的确降低了网络的通信量,不过虽然 btnInToOut 没有效果,但仍然进行了通信。

我们选中第四个会话,然后切换到 Session Inspector 标签,在下面的工作栏中单击“TextView”,可以得到类似如下的数据:



我们选中第三个会话,然后切换到 Session Inspector 标签,在下面的工作栏中单击“TextView”,可以得到类似如下的数据:



观察小结

由此看出 UpdatePanel 之内的控件产生的事件不是传送的整个网页,而 UpdatePanel 之外的控件产生的事件传送的是整个网页。

更进一步

我们发现,在点击 btnIn、btnInToOut 时,我们获得的真正有用的数据只有很短的一个字符串,那为什么还有几百字节的传输量呢?通过 Fiddler 我们发现服务器端发送回来的数据不仅包括了我们需要的数据,还包括了整个 UpdatePanel 内部的数据,这的确是一件危险的事情,如果我们的 UpdatePanel 很大,那么 UpdatePanel 的确应该慎用。

分享到:
评论

相关推荐

    Fiddler使用说明.docx

    【Fiddler 使用详解】 Fiddler是一款强大的HTTP抓包工具,它扮演着客户端和服务器间的HTTP代理角色,让你能够观察并分析所有的HTTP通信。它不仅记录请求,还能进行调试、设置断点、修改请求和响应数据,是Web开发者...

    fiddler常用功能说明.pptx

    Fiddler是位于客户端和服务器端之间的代理,也是目前最常用的抓包工具之一 。它能够记录客户端和服务器之间的所有 请求,可以针对特定的请求,分析请求数据、设置断点、调试web应用、修改请求的数据,甚至可以修改...

    FiddlerCore官网API接口与使用说明帮助文档

    FiddlerCore是一款强大的网络调试工具,它是Fiddler的.NET库版本,允许开发者在自己的应用程序中集成网络抓包和分析功能。FiddlerCore API提供了丰富的接口,可以帮助程序员深入理解网络请求和响应的细节,从而优化...

    Fiddler (v4.6.1.5)_汉化版和原版

    Fiddler是一款强大的网络调试工具,特别适用于Web应用程序的开发者和测试人员。它是由 Telerik 公司开发的,主要用于捕获、分析和修改在客户端和服务器之间交换的HTTP(S)数据包。在这个“Fiddler (v4.6.1.5)_汉化版...

    Microsoft Fiddler V2.4.1.0.zip

    【说明.htm】文件通常包含有关软件的基本使用指南和注意事项。对于初学者来说,这份文档是快速上手Fiddler的好帮手。它会解释如何启动Fiddler、配置代理设置、查看和分析会话,以及如何利用Fiddler的高级特性进行...

    抓包软件Fiddler5-116835.rar

    安装必看.txt可能包含了关于Fiddler5安装和配置的注意事项,软件说明.url和当快软件园的相关链接提供了更多的资源和下载信息。确保正确安装并配置Fiddler,阅读这些文档是使用前的重要步骤。Fiddler5程序本身则包含...

    HTTP调试工具:Fiddler的使用方法介绍.pdf

    以下是对Fiddler主要功能的详细说明: 1. **记录HTTP交互**:Fiddler可以捕获并显示所有通过Microsoft Internet Explorer和Web应用程序发起的HTTP请求和响应,包括请求头、响应头、cookies和请求体内容。这使得...

    Fiddler导出jmeter脚本.pdf

    下面详细说明通过Fiddler导出jmeter脚本的步骤和相关知识点。 首先,要进行Fiddler导出jmeter脚本的前提条件是需要有Fiddler的安装包,并且下载相应的Fiddler插件。Fiddler是一款免费的网络抓包工具,可以捕获和...

    抓包工具Fiddler4.zip

    简洁好用的抓包软件,该资源包括Fiddler安装包、证书生成工具、抓包基础教程、捕获https连接的设置方法四个文件。

    Fiddler Web Debugger (V4.6.3.50306)修正中文一版

    用户可以参考提供的“协议冲突报告说明.jpg”,了解如何识别和解决这类问题。 5. **安全提示**: - “主程序已加壳,部分杀软提示病毒情况.txt”表明Fiddler的主程序可能被安全软件误报为病毒。这是因为加壳技术...

    Fiddler 2.3.5.2 HTTP调试工具

    软件说明 —————————————————— 软件名称:Fiddler v2.3.5.2 软件类别:HTTP调试工具 运行环境:Win2003, WinXp, Win2000, Win9x 授权方式:免费 软件介绍: Fiddler 是一款HTTP调试工具 ,可以帮...

    Fiddler手机抓包v4.6.1.5汉化版.zip

    fiddler抓包工具不仅能够抓取pc端,还可以抓取手机端,这个是中文汉化版,对于英盲的同学非常有用。一款HTTP抓包工具也是WEB调试工具,能够记录所有服务端和客户端的HTTP/HTTPS请求,你可以自定义设置断点、监视及...

    夜神模拟器_6.6.1.1.rar及Fiddler使用文档

    提供的"使用说明.docx"文档应包含了关于如何配置和使用Fiddler抓取夜神模拟器网络流量的详细步骤,包括可能遇到的问题和解决方案,建议仔细阅读并参照执行。 总的来说,夜神模拟器和Fiddler的结合使用,为开发者...

    Fiddler2安装程序及使用说明

    提供的`使用说明.txt`文件应当包含了更详尽的步骤和技巧,包括如何设置代理、使用断点、编写脚本等内容。建议在实际操作中参照这个文档,以便更好地掌握Fiddler2的使用。 总结来说,Fiddler2作为一款强大的HTTP调试...

    Fiddler介绍和使用说明

    文档详细介绍了Fiddler的功能,包括工具栏,监控面板,右面板,状态栏,非常适合Fiddler初学者,初次之外还介绍了做测试的一些常用方法

    fiddler2setup.zip

    **Readme-说明.htm** 文件通常包含了软件的详细使用说明、版权信息以及可能的更新日志。在遇到具体问题或想要深入了解软件功能时,这是一个非常重要的参考资料。 总的来说,Fiddler2是一个强大且功能丰富的HTTP调试...

    fiddler5网络监控工具.rar

    本人使用fiddler5解决VS2017到期记录一下 VS 2017 RC到期的解决方法 Visual Studio 2017 enterprise RC版有使用期限限制,到期会强制退出不让使用。 解决方法: 1,安装Fiddler,打开之 2,菜单栏Under Tools -> ...

    抓包工具 fiddler5.0.20 支持https 附带安装说明

    6. 最后,参考`fillder支持https-使用说明.txt`中的详细步骤,以确保正确配置了所有必要步骤。 **功能特性** Fiddler的强大之处在于其丰富的功能: - **捕获流量**:可以看到每个HTTP/HTTPS请求的详细信息,包括...

    fiddler中文包

    以下是对Fiddler中文包及其相关组件的详细说明: 1. **Fiddler安装步骤**: - 首先,你需要下载提供的压缩包,并将其解压缩到你的本地文件夹。 - 解压后,找到"Fiddler (v4.6.1.5)_汉化版.exe"这个文件,这便是...

    Fiddler--已完成.docx

    * 头部字段集合(header):使用 key-value 形式更详细的说明报文 * 空一行 * 消息正文(entity):实际传输的数据,它不一定是纯文本,可以是图片、视频等二进制数据 3. 请求报文 * 请求行(request line):...

Global site tag (gtag.js) - Google Analytics