认识FiddlerScript

时间:2023-03-08 18:39:08

FiddlerScript 是Fiddler 的一项非常强大的功能,它允许你增强Fiddler UI,添加新的特性,修改请求与响应内容等等。。。

1.编写FiddlerScript

FiddlerScript 基于JScript.NET 语言。在Fiddler 中点击菜单“Rules > Customize Rules”打开FiddlerScript Editor 编辑器,在这里可以编写Fiddler Script 脚本,只要一保存,Fiddler 将会重新编译脚本并自动加载,如果加载成功,则会播放声音并在Fiddler 状态栏显示"CustomRules.js was loaded at <datetime>" 提示信息,如果编译失败,将会显示错误提示信息。

如果你没有安装FiddlerScript Editor 插件,也可以在其他编辑器编写脚本,但是推荐使用FiddlerScript Editor编辑器,因为它具有语法高亮以及自动完成功能,下载地址http://fiddler2.com/fiddlerscript-editor

认识FiddlerScript

如果你想使用其他编辑器编写FiddlerScript,可以在Tools > Fiddler Options 中设置,如下设置使用notepad++作为编辑器:

认识FiddlerScript

如果编写脚本时需要引用第三方.net程序集,可以在按如下方式添加:

a.在References文本框中填写需要引用的程序集地址,如果有多个以分号分隔。

认识FiddlerScript

b.也可将程序集注册到GAC中,或者将程序集复制到Fidder.exe安装的目录下。

添加好程序集之后,就可以在编写脚本时用Import语句导入程序集的命名空间。

编写的自定义脚本文件CustomRules.js 保存在用户的我的文档目录下:

win7系统位于:C:\Users\[your user]\Documents\Fiddler2\Scripts\

xp系统位于: C:\Documents and Settings\[your user]\My Documents\Fiddler2\Scripts\

认识FiddlerScript

如果不想再使用自定义规则时,可以删除些文件,下次启动Fiddler 时,FiddlerScript Editor将会使用安装目录下的SampleRules.js 重新生成该文件。

2.FiddlerScript 中的主要方法

你的FiddlerScript 文件中包含一个静态类Handlers,一般来说,你的代码应该写在这个类的静态方法中。

Fiddler 运行时会自动执行一些" Application event methods":

static function OnBoot fiddler 启动时调用
static function OnShutdown fiddler关闭时调用
static function OnAttach fiddler注册成系统代理时调用
static function OnDetach fiddler 取消注册系统代理时调用
static function Main 在每次fiddler启动时和编译CustomRules.js 脚本时调用。

 

// 在这个方法中修改Request的内容, 我们用得最多

static function OnBeforeRequest(oSession: Session)

// 在这个方法中修改Response的内容

static function OnBeforeResponse(oSession: Session)

// 在个方法中包含Fiddler 命令,在Fiddler界面中左下方的QuickExec Box,如果你的脚本处理了指定的命令,则返回true,否则返回false.

static function OnExecAction(sParams: String[])

3.FiddlerScript 与Attributes

Handlers 类允许你使用attributes 注解对外暴露的字段或者方法,可以使这些字段出现在Fiddler UI界面中。

使用BindUIColumn attribute 为方法添加注解,可以添加列到web 会话列表中:

public static BindUIColumn("Method", 60)
function static FillMethodColumn(oS: Session): String {
return oS.RequestMethod;
}

只要保存脚本就可以看到fiddler会话列表多了一个请求方式列,标记当前请求的方式。

认识FiddlerScript

使用QuickLinks attribute 添加最顶层的菜单:

QuickLinkMenu("&Links")
QuickLinkItem("财付通", "https://www.tenpay.com")
QuickLinkItem("支付宝", "https://www.alipay.com")
public static function DoLinksMenu(sText: String, sAction: String)
{
Utilities.LaunchHyperlink(sAction);
}

保存脚本将会看到Fiddler 最上面多了一个菜单项,点击菜单项并可以打开相应的网站

认识FiddlerScript

4.修改Session在Fiddler的显示样式

我们可以控制Session在Fiddler中显示的样式, 具体文档是: http://www.fiddlerbook.com/Fiddler/dev/SessionFlags.asp

把这段脚本放在OnBeforeRequest(oSession: Session) 方法下,并且点击"Save script", 这样所有的www.tenpay.com 的会话都会显示红色.

if (oSession.HostnameIs("www.tenpay.com")){
oSession["ui-color"] = "red";
}

认识FiddlerScript

5.Fiddler Script中修改Cookie

cookie其实就是request 中的一个header.

// 删除所有的cookie

oSession.oRequest.headers.Remove("Cookie");

// 新建cookie

oSession.oRequest.headers.Add("Cookie", "username=testname;loginpwd=123456");

注意: Fiddler script不能直接删除或者编辑单独的一个cookie, 你需要用replace方法或者正则表达式的方法去操作cookie的string

static function OnBeforeRequest(oSession: Session)
{
if (oSession.HostnameIs('www.example.com') &&
oSession.uriContains('pagewithCookie') &&
oSession.oRequest.headers.Contains("Cookie"))
{ var sCookie = oSession.oRequest["Cookie"]; // 用replace方法或者正则表达式的方法去操作cookie的string
sCookie = sCookie.Replace("cookieName=", "ignoreme="); oSession.oRequest["Cookie"] = sCookie;
}

6.在Fiddler Script中修改Request 中的body

方法一:

static function OnBeforeRequest(oSession: Session)
{
if(oSession.uriContains("http://www.cnblogs.com/TankXiao/"))
{
// 获取Request 中的body字符串
var strBody=oSession.GetRequestBodyAsString();
// 用正则表达式或者replace方法去修改string
strBody=strBody.replace("1111","2222");
// 弹个对话框检查下修改后的body
FiddlerObject.alert(strBody);
// 将修改后的body,重新写回Request中
oSession.utilSetRequestBody(strBody);
}
}

方法二:提供了一个非常简单的方法,可以直接替换body中的数据

oSession.utilReplaceInRequest("1111", "2222");

 

7.其它参考资料

JScript.NET语言参考:http://msdn.microsoft.com/en-us/library/z688wt03(VS.80).aspx

控制Session 的UI样式:http://www.fiddlerbook.com/Fiddler/dev/SessionFlags.asp

Fiddler Script 的官方帮助文档:http://www.fiddlerbook.com/Fiddler/dev/ScriptSamples.asp

修改Fiddler 请求与响应:http://fiddler2.com/documentation/KnowledgeBase/FiddlerScript/ModifyRequestOrResponse

Fiddler Blog: http://www.telerik.com/automated-testing-tools/blog/eric-lawrence.aspx