tpl (xtpl)

xtpl功能同tpl一样,和tpl的唯一区别是tpl找不到对应文件返回404,而xtpl则是继续请求线上资源。

tpl基本功能跟file一样可以做本地替换,但tpl内置了一个简单的模板引擎,可以把文件内容里面{name}替换请求参数对应的字段(如果不存在对应的自动则不会进行替换),一般可用于mock jsonp的请求。

配置方式:

pattern tpl://filepath
# 也可以匹配一个文件或目录路径列表,whistle会依次查找直到找到存在的文件
pattern tpl://path1|path2|pathN

filepath为Values里面的{key}或者本地文件。

例子:

    /\.jsonp/i  tpl://{test.json}

test.json:

    {callback}({ec: 0})

请求 http://www.test.com/test/xxx.jsonp?callback=imcallbackfn 会返回 imcallbackfn({ec: 0})

过滤规则

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

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

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

例子:

# 下面表示匹配pattern的同时不能为post请求且请求头里面的cookie字段必须包含test(忽略大小写)、url里面必须包含 cgi-bin 的请求
# 即:过滤掉匹配filter里面的请求
pattern operator1 operator2 filter://m:post filter://h:cookie!=test filter://!/cgi-bin/i

# 下面表示匹配pattern1、pattern2的同时必须为post请求且请求头里面的cookie字段不能包含类似 `uin=123123`、且url里面不能包含 cgi-bin 的请求
operator pattern1 pattern2 filter://m:!post filter://h:cookie=/uin=o\d+/i filter:///cgi-bin/i

# 下面表示匹配pattern的请求忽略除了host以外的所有规则
pattern ignore://*|!host

# 下面表示匹配pattern的请求忽略file和host协议的规则
pattern ignore://file|host

results matching ""

    No results matching ""