- resMerge
- 例子
- 过滤规则
- 过滤规则
- 例子
resMerge
修改响应类型为
application/json
或text/javascript
的响应内容,其功能是通过resMerge://jsonData
指定的JSON对象覆盖响应内容里面的JSON对象,请个文本响应类型的修改可以参考:resReplace
配置方式:
pattern resMerge://filepath
filepath为Values里面的{key}或者本地文件(如:e:\test\xxx
、e:/test/xxx
、/User/username/test/xxx
等):
field1: value1
field2: value2
filedN: valueN
pattern参见匹配模式,更多模式请参考配置方式,json格式参考操作值。
例子
- 普通的返回JSON对象的请求:
www.test.com/cgi-bin/get-data resMerge://(name=1&value=2)
一般配置左边是pattern、右边是operator,如果pattern和operator可以区分开来则位置可以调换(高亮显示的颜色不一样),有关pattern可以参考:匹配模式
上述配置,请求 https://www.test.com/cgi-bin/get-data?xxx
如果响应类型为 application/json
,且返回内容为json格式:
{"name":"test"}
经过whistle后在浏览器会收到:
{"name":1,"value":2}
覆盖方式是深度覆盖
- jsonp请求(jsonp请求的返回类型必须为
text/javascript
):www.test.com/cgi-bin/test-jsonp resMerge://{jsonp.json}
Values里面的jsonp.json
对象:
{
"name": "avenwu",
"obj": {
"test": 1,
"new": 2
}
}
上述配置,请求 https://www.test.com/cgi-bin/get-data?xxx
如果响应类型为 application/json
,且返回内容为json格式:
{"name":"test","obj":{"test":"hehe"}}
经过whistle后在浏览器会收到:
{"name": "avenwu","obj":{"test":"hehe","new":2}}
括号的写法见:Rules的特殊操作符({}、()、<>)
过滤规则
需要确保whistle是最新版本:更新whistle
如果要过滤指定请求或指定协议的规则匹配,可以用如下协议:
- ignore:忽略指定规则
- filter:过滤指定pattern,支持根据请求方法、请求头、请求客户端IP过滤
例子:
# 下面表示匹配pattern的同时不能为post请求且请求头里面的cookie字段必须包含test(忽略大小写)、url里面必须包含 cgi-bin 的请求
# 即:过滤掉匹配filter里面的请求
pattern operator1 operator2 excludeFilter://m:post includeFilter://h:cookie=test includeFilter:///cgi-bin/i
# 下面表示匹配pattern1、pattern2的请求方法为post、或请求头里面的cookie字段不能包含类似 `uin=123123` 且url里面必须包含 cgi-bin 的请求
operator pattern1 pattern2 includeFilter://m:post excludeFilter://h:cookie=/uin=o\d+/i excludeFilter:///cgi-bin/i
# 下面表示匹配pattern的请求忽略除了host以外的所有规则
pattern ignore://*|!host
# 下面表示匹配pattern的请求忽略file和host协议的规则
pattern ignore://file|host