场景:
目标app有个类似于开心消消乐精力的参数:精力未达到一定值时,不能闯关。“精力”值通过接口获取,现在想通过修改接口返回的这个“精力”值,让被测业务不受这个参数的限制。
方法一: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复制出来:
新建一个txt文档,粘贴复制的内容,修改目标字段值,保存后关闭文档并修改文件类型(目标接口返回的是json串,所以文件名修改为XXX.json)。
然后在Fiddler的右边选中“AutoResponder”,对目标url进行自动响应的设置,操作如下:
点击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);
}
}
}
}
与方法三比起来,这种方法相对灵活,如果后期接口响应结果中增加了内容,也不需要处理,而方法三需要重新复制、粘贴、修改内容。