Fiddler大师之路系列(五)

需求


在开发/测试过程中有多台设备(PC/手机/模拟器)通过 Fiddler 代理上网时,如何方便地从满屏纷飞的 Session 中筛选出自己关心的那台设备的请求?


设想


通过 FiddlerScript 扩展,在 Session 的右键弹出菜单中添加一项,作为“查看所有设备请求”和“查看单个设备请求”的切换开关。

设计操作流程:

  1. 找到自己关心的设备发出的某一条请求,在它的右键弹出菜单里有我们添加的菜单项“开/关过滤单设备请求”。

  2. 点击该菜单项后:

    • 若当前状态为“查看所有设备请求”,则切换为“查看单个设备请求”状态,该设备为此条请求的发送者,并清除当前已显示的所有不关心的设备的请求。

    • 若当前状态为“查看单个设备请求”,则切换为“查看所有设备请求”状态。


实现


实现思路:

  • 通过修改 CustomRules.js,在右键弹出菜单上添加一个菜单项来切换请求筛选状态。

  • 每一条请求都带有 ClientIP,它在没有网络切换之类的情况发生时能较好地唯一标识一台设备。

  • 筛选规则是将非来自该 ClientIP 的请求隐藏掉。

实现步骤:

1. 打开 CustomRules.js。

启动Fiddler,依次选择菜单 Rules > Customize Rules...

2. 在 OnBeforeRequest 前添加如下代码:

// 是否过滤单设备请求标志
public static var gs_FilterDevice: boolean = false;
// 显示请求的设备的 
ClientIPpublic static var gs_FilterClientIP: String = null;
static function IsUnMatchClientIP(oS:Session):Boolean {
    return (oS.m_clientIP != gs_FilterClientIP);
}
public static ContextAction("开/关过滤单设备请求")
function ToggleDeviceFilter(oSessions: Fiddler.Session[]){
    if (gs_FilterDevice) {
        gs_FilterDevice = false;
        return;
    }
    var oS: Session = FiddlerApplication.UI.GetFirstSelectedSession();
    if (null == oS) return;
    if (!gs_FilterDevice) {
        gs_FilterDevice = true;
    }
    gs_FilterClientIP = oS.clientIP;

    // 删除当前已显示的非所关心设备的请求
    FiddlerApplication.UI.actSelectSessionsMatchingCriteria(IsUnMatchClientIP);
    FiddlerApplication.UI.actRemoveSelectedSessions();
}

3. 在 OnBeforeRequest 函数里添加如下代码,用于在“查看单个设备请求”状态时将不关心的设备产生的新请求隐藏:

if (gs_FilterDevice && oSession.m_clientIP != gs_FilterClientIP) {
    oSession["ui-hide"] = "true";
}


最终效果如下图:

  • 筛选前

  • 筛选后


缺陷


当前做法有如下缺陷,尚未想到好办法解决:

  • 菜单项并不能标明当前的状态,不知道筛选是开是关,这可以通过查看当前 Session 列表里是否有多种设备的请求来判断。

  • 当设备有网络切换时,比如重启了路由或者离开又回到某 Wifi,ClientIP 可能发生了变化,需要关闭筛选后在设备以新的 ClientIP 产生的请求上右键再次开启筛选。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值