• resScript (resRules)
    • 静态规则列表
    • 通过脚本动态设置规则
      • 过滤规则

    resScript (resRules)

    给匹配的响应批量设置规则,或者通过脚本动态设置规则,配置方式:

    1. pattern resScript://filepath resRules://filepath1 resRules://filepath2 resRules://filepath3

    filepath为Values里面的{key}或者本地js文件(如:e:\test\xxxe:/test/xxx/User/username/test/xxx等),pattern参见匹配模式,更多模式请参考配置方式。

    filepath指定的文本可以为一组规则列表,也可以一个js脚本通过判断url、method、clientIp、headers, body动态设置规则:

    resScript 可以设置规则或者脚本,但只能设置一个,resRules 可以同时设置多个,但只能设置规则,不能设置脚本

    静态规则列表

    whistle判断如果文件的第一行为规则的注释,即#开头,则任务filepath指定的是规则列表,会加载该列表,并进行二次匹配获取规则:

    1. # rules
    2. pattern1 operatorURI1
    3. pattern2 operatorURI2
    4. patternN operatorURIN

    通过脚本动态设置规则

    rulesFile可以指定一个脚本,whistle在执行脚本时会自动在全局传人:

    1. url: 请求的完整路径
    2. method: 请求方法
    3. ip(clientIp): 客户端ip
    4. headers: 请求头部
    5. body: 请求内容(只有匹配了reqScript才会有该字段),如果没有请求内容为空字符串(''),如果请求内容大于16k,可能只能获取请求前面16k长度的内容(whistle >= v1.5.18)
    6. rules: 存放新规则的数组
    7. values: 存放临时values的对象(v1.7.1开始支持)
    8. render(tplStr, data): 内置microTemplate,方便通过模板渲染数据(v1.7.1开始支持)
    9. getValue(key): 获取Values中对应key的值(v1.7.1开始支持)
    10. parseUrl: 同 url.parse(v1.7.1开始支持)
    11. parseQuery: 同 querystring.parse(v1.7.1开始支持)
    12. statusCode: 响应状态码(v1.7.1开始支持)
    13. resHeaders: 响应头(v1.7.1开始支持)
    14. serverIp: 服务器ip(v1.7.1开始支持)

    用该方法可以解决此问题#19,也可以用来做ip_hash等,具体用法看下面的例子

    例子:

    设置静态规则列表

    1. www.ifeng.com resScript://{resScript.txt}

    resScript.txt:

    1. # 第一行没有这个注释符号,whistle会认为是一个脚本
    2. http://www.ifeng.com/index.html redirect://http://www.ifeng.com/?test
    3. www.ifeng.com resType://text

    通过脚本设置规则列表

    1. www.ifeng.com resScript://{resScript.js}

    resScript.js:

    1. const options = parseUrl(url);
    2. rules.push(`${options.host} resCookies://{cookies.json}`);
    3. values['cookies.json'] = {
    4. serverIp,
    5. clientIp,
    6. from: 'resScript'
    7. };

    过滤规则

    需要确保whistle是最新版本:更新whistle

    如果要过滤指定请求或指定协议的规则匹配,可以用如下协议:

    1. ignore:忽略指定规则
    2. filter:过滤指定pattern,支持根据请求方法、请求头、请求客户端IP过滤

    例子:

    1. # 下面表示匹配pattern的同时不能为post请求且请求头里面的cookie字段必须包含test(忽略大小写)、url里面必须包含 cgi-bin 的请求
    2. # 即:过滤掉匹配filter里面的请求
    3. pattern operator1 operator2 excludeFilter://m:post includeFilter://h:cookie=test includeFilter:///cgi-bin/i
    4. # 下面表示匹配pattern1、pattern2的请求方法为post、或请求头里面的cookie字段不能包含类似 `uin=123123` 且url里面必须包含 cgi-bin 的请求
    5. operator pattern1 pattern2 includeFilter://m:post excludeFilter://h:cookie=/uin=o\d+/i excludeFilter:///cgi-bin/i
    6. # 下面表示匹配pattern的请求忽略除了host以外的所有规则
    7. pattern ignore://*|!host
    8. # 下面表示匹配pattern的请求忽略file和host协议的规则
    9. pattern ignore://file|host