Fiddler教程 第五节:​​修改RESPONSE的数据

修改response的数据(一)

​在项目中也经常也会碰到根据接口返回的数据不同而展示不同的效果。如果单个单个去真实的造数据会比较麻烦,况且有时候造数据也是一件很麻烦甚至无从下手的事情。

Fiddler可以修改response的数据,可以很轻松方便的解决我们造数据的苦恼。

修改response的数据

在修改数据之前,需要先明白在哪里修改这些数据,需要知道如下的函数: static function OnBeforeResponse(oSession: Session) 在请求返回之前执行的函数,所以修改response的数据就在此函数中。

修改数据

需求是:会为返回的JSON中修改一个字段的数据,将click_url的值变更一下。

核心流程图

在 OnBeforeResponse(oSession: Session) 中添加以下的代码

static function OnBeforeResponse(oSession: Session) {

    //将美国的fixfor的clickurl替换成这个新加坡请求的clickurl

    if (oSession.uriContains("flow/intercept")){

        oSession["ui-color"] = "red";

        var newclickurl: String = "http://pixel.admobclick.com/v1/click";

        // 获取Response Body中JSON字符串

        var responseStringOriginal =  oSession.GetResponseBodyAsString();

        // 转换为可编辑的JSONObject变量

        var responseJSON = Fiddler.WebFormats.JSON.JsonDecode(responseStringOriginal);

        // 修改JSONObject变量,修改字段数据

        responseJSON.JSONObject["click_url"] = newclickurl;

        // 重新设置Response Body

        var responseStringDestinal = Fiddler.WebFormats.JSON.JsonEncode(responseJSON.JSONObject);

        oSession.utilSetResponseBody(responseStringDestinal);

    }

}

代码调整之后,一定要重启Fiddler重新加载CustomRules.js。



修改response的数据(二)

添加数据

有时候也会需要给response的返回内容中添加数据,它的原理和基本流程和上一节课讲的一样,在这里就不再重复的说明。

static function OnBeforeResponse(oSession: Session) {

    if (oSession.uriContains("ads/sdk/v4")){

        oSession["ui-color"] = "red";

        var tester1 = "{ \"name\" : \"zwf\" , \"age\" : \" 26 \" }";

        var tester2 = "{ \"name\" : \"zch\" , \"age\" : \" 24 \" }";

        var testerList = "["+tester1 +"," + tester2 +"]";

        var responseStringOriginal =  oSession.GetResponseBodyAsString();

        //以alter的方式弹个对话框提示json字符串内容,可以方便用来调试

        //  FiddlerObject.alert(responseStringOriginal);

        //转换成JSON之后,数据的读取就设计到json的相关知识点了,这里就不做介绍了

        var responseJSON = Fiddler.WebFormats.JSON.JsonDecode(responseStringOriginal);

        responseJSON.JSONObject[0]["key"] = "zwfGood";

        responseJSON.JSONObject[0]["testerList"] = Fiddler.WebFormats.JSON.JsonDecode(testerList).JSONObject ;

        var responseStringDestinal = Fiddler.WebFormats.JSON.JsonEncode(responseJSON.JSONObject);

        oSession.utilSetResponseBody(responseStringDestinal);

    }

}

修改之前的json数据:


修改之后的json数据:




​修改Response的数据(三)

之前的教程中有讲到如何通过修改CustomRules.js文件来达到修改Response数据的目的,今天我们来分享如何在打断点的时候修改Response

1、打断点

之前有讲到,若是修改响应的数据,应该在after response 打断点,故打断点的步骤是,Rules->Automatic Breakpoints -> After Responses


如下图所示,请求被阻止:


右下角的页签,切换到Transformer


做如下的操作:

取消 Chunked Transfer-Encoding 的选择,该项默认是被选中的。

HTTP Compression 选择 None

怎么解释这些操作的意思呢?

官方是这样解释的:

To improve performance, response bodies may be compressed and/or delivered in chunks. Before examining or modifying such responses, you may wish to decompress or unchunk them using the Transformer.

大概意思就是说,为了提高性能,响应体是有被压缩或者采用chunked(块)的方式传输,但是如果你要修改响应体,则希望是不压缩不编码.

仔细的讲解一下这一块:

如下图所示,这是默认的选项:


切换到Raw选项,如下图所示:


如果取消了Chunked Transfer-Encoding,选择了None,查看Raw


2、修改response

好,接着我们的打断点修改Response,修改响应体当然也就是修改Raw的内容了,切换到Raw,就可以修改内容了:


修改之后,点击 Run to Completion ,接口响应200 ,数据修改成功!


这种方式是不是更简单一点呢,不用去view代码,但是如果要多次执行时,每一次操作都要这样修改,比较繁琐,而且很容易造成错误。

两种方法都可以,没有哪个好哪个不好,选择适合自己的就很好!


日拱一卒无有尽,

功不唐捐终入海。

——谱儿

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
禁止转载,如需转载请通过简信或评论联系作者。
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 204,445评论 6 478
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,889评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 151,047评论 0 337
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,760评论 1 276
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,745评论 5 367
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,638评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,011评论 3 398
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,669评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,923评论 1 299
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,655评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,740评论 1 330
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,406评论 4 320
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,995评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,961评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,197评论 1 260
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 45,023评论 2 350
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,483评论 2 342

推荐阅读更多精彩内容