这篇文章是给搜狗测试公众号投稿的,没想到落榜了,还是写在自己的博客吧,毕竟我觉得这个是满满的干货

模拟场景: 脚本实现阻塞请求A,等待N秒之后,自动放行请求A
因为项目的业务逻辑,需要模拟这样的场景,刚开始我也很纠结郁闷,觉得无从下手,还不如手工来的快一些,因为涉及到时间,又不敢保证每次手工操作的准确性。没办法,只能硬着头皮啃这个大难题,
后来我就把这个问题一步步拆解,化繁为简,之后再逐渐攻克每一个难点,这样就在不知不觉中解决了这个疑难杂症。

思路: 第一问: 如何让请求阻塞呢?

之前都是在界面上执行命令,bpu * ,bpafter ,怎么用脚本来实现遇到请求A就自动拦截呢?这个我们就要深挖在界面上【QuickExec box】执行命令之后的秘密了。
在CustomRules.js文档中,会发现如下的代码:

    // The OnExecAction function is called by either the QuickExec box in the Fiddler window,
    // or by the ExecAction.exe command line utility.
    static function OnExecAction(sParams: String[]): Boolean {
    ......
    //取数组的第一个值,第一个值存放的是执行的命令
    var sAction = sParams[0].toLowerCase();
        switch (sAction) {
            case "bpafter":
                var len = sParams.Length ;
                //如果sParams 长度小于2,也就意味着bpafter后面没有跟url,那么就清空bpafter 阻塞的url,下次再遇到此url 就不会再阻塞了
                if (sParams.Length<2) {bpResponseURI=null; FiddlerObject.StatusText="ResponseURI breakpoint cleared"; return false;}
                var len = sParams.Length ;
                //取数组的第二个值,第二个值存放的是要截取的url
                bpResponseURI = sParams[1]; 
                FiddlerObject.StatusText="ResponseURI breakpoint for "+sParams[1];
                return true;
        }
    ......
    }

OnExecAction 这个函数就是在界面上执行命令所调用的函数,sParams 是将输入的内容用空格分割而成的数组。
例如,bpafter /altamob/zwf ,那么 sParams[0] = "bpafter" ; sParams[1] = "/altamob/zwf" ;
明白了这个操作的原理,如果想阻塞某个请求,只要调用此函数就可以了。

    if (oSession.uriContains("A")){
            oSession["ui-color"] = "purple";
            var command1:String[] = ["bpafter","/altamob/zwf"];
            OnExecAction(command1);
    }

第二问:如何让等待N秒呢?
CustomRules.js 是JS 的脚本文档,我们可以用jS来实现此功能,这个是很常见的代码。

    static function sleep(numberMillis) { 
        var now = new Date(); 
        var exitTime = now.getTime() + numberMillis; 
        while (true) { 
            now = new Date(); 
            if (now.getTime() > exitTime) 
                return; 
        } 
    }

单位是ms,等待2s中,sleep(2000); 这样调用即可
第三问:如何自动放行呢?
go 命令是放行所有被中断的会话。关键是在哪一步执行此命令呢?
发现了这样一个被注释掉的函数

// This function executes after Fiddler finishes processing a Session, regardless
// of whether it succeeded or failed. Note that this typically runs AFTER the last
// update of the Web Sessions UI listitem, so you must manually refresh the Session's
// UI if you intend to change it.
    static function OnDone(oSession: Session) {
    }

看上面的注解,This function executes after Fiddler finishes processing a Session, regardless of whether it succeeded or failed,
不管一个session 成功或者失败,在fiddler 结束处理这个session之后,这个函数就会被执行。我的英文翻译真的是很烂,但是意思是这么个意思,
就是处理完一个session,肯定会调用此函数。那么在此函数中将阻塞放行就ok了。

    static function OnDone(oSession: Session) {
            if (oSession.uriContains("A")){
                sleep(1000);
                var command1:String[] = ["go"];
                OnExecAction(command1);
            }   
    }

【相关书籍:Fiddler抓包让数据无处可藏】https://yuedu.baidu.com/ebook/52dc548fe109581b6bd97f19227916888586b950
【相关书籍:玩转Fiddler】https://yuedu.baidu.com/ebook/2a08ad280a4e767f5acfa1c7aa00b52acfc79cd5