Fiddler修改响应数据

作者: 喵喵Alin | 来源:发表于2020-04-29 14:44 被阅读0次

    场景:
    目标app有个类似于开心消消乐精力的参数:精力未达到一定值时,不能闯关。“精力”值通过接口获取,现在想通过修改接口返回的这个“精力”值,让被测业务不受这个参数的限制。

    方法一:Automatic Breakpoints功能

    直接上图

    Automatic Breakpoints

    我需要修改的是接口的返回内容,所以选择After Response,在接口响应时,会自动拦截

    拦截并修改响应数据

    这种方法有个缺点:所有请求的响应都会被拦截,我只需要修改某个接口的响应数据,显然这个方法不合适。


    方法二:命令

    先上命令:

    1)请求打断点:bpu XXX,取消断点:bpu+Enter
    2)响应打断点:bpafter XXX,取消断点:bpafter+Enter

    "XXX" 可以是完整的url,也可以是url中的一部分,如:

    bpafter https://news.163.com/20/0428/15/FBAENVS0000189FH.html
    bpafter https://news.163.com
    bpafter /20/0428/
    

    猜测这个命令的逻辑就是从目标字符串中查找子字符串,查找到了就拦截

    下面实操:
    PS:Fidder的命令行在左边的底部,不注意看还真难发现

    设置响应断点
    接下来修改数据的操作和方法一中的一样,在命令行中输入“bpafter”,然后回车,取消断点。

    这种方法相比第一种方法,能精确到某一个请求,但在没有取消断点前,每次都要手动点下“Go”或者“Run to Completion”。
    那有没有一种方法能在拦截后就自动响应修改后的数据呢?
    有!


    方法三:AutoResponder

    首先在Fiddler中把响应body复制出来:

    复制respond body

    新建一个txt文档,粘贴复制的内容,修改目标字段值,保存后关闭文档并修改文件类型(目标接口返回的是json串,所以文件名修改为XXX.json)。

    然后在Fiddler的右边选中“AutoResponder”,对目标url进行自动响应的设置,操作如下:

    启用AutoResponder

    点击Rule Editor中第二行右边的箭头,会出来一个下拉列表,选择“Find a file...",选择刚保存的json文件。

    指定响应文件

    到此,自动响应就设置好了,每次都会返回我想要的数据。
    如果需要接口的正常响应数据,就把AutoResponder下的”Enable rules“取消勾选。


    方法四:修改脚本

    这个方法需要有点js的代码基础
    首先,打开脚本编辑器:

    找到OnBeforeResponse这个方法,添加脚本:

    static function OnBeforeResponse(oSession: Session) {
            if (m_Hide304s && oSession.responseCode == 304) {
                oSession["ui-hide"] = "true";
            }
            // 以下是新加的
            if (oSession.host == "xxx.com")  {
                if (oSession.fullUrl.Contains("XXX")) {
                    var responseStringOriginal =  oSession.GetResponseBodyAsString();
                    var responseJSON = Fiddler.WebFormats.JSON.JsonDecode(responseStringOriginal);
                    if (0==responseJSON.JSONObject['code']) { //code=0表示接口正常的响应,根据实际情况删减
                        responseJSON.JSONObject['data']['xxx'] = "XXX"; //替换xxx字段的值
                        var responseStringDestinal = Fiddler.WebFormats.JSON.JsonEncode(responseJSON.JSONObject);
                        oSession.utilSetResponseBody(responseStringDestinal);
                    }
                }
            }
        }
    

    与方法三比起来,这种方法相对灵活,如果后期接口响应结果中增加了内容,也不需要处理,而方法三需要重新复制、粘贴、修改内容。

    相关文章

      网友评论

        本文标题:Fiddler修改响应数据

        本文链接:https://www.haomeiwen.com/subject/coyjwhtx.html