mirror of
https://github.com/alibaba/higress.git
synced 2026-02-21 06:20:54 +08:00
85 lines
2.7 KiB
Markdown
85 lines
2.7 KiB
Markdown
<p>
|
||
<a href="README_EN.md"> English </a> | 中文
|
||
</p>
|
||
|
||
# 功能说明
|
||
`custom-response`插件支持配置自定义的响应,包括自定义 HTTP 应答状态码、HTTP 应答头,以及 HTTP 应答 Body。可以用于 Mock 响应,也可以用于判断特定状态码后给出自定义应答,例如在触发网关限流策略时实现自定义响应。
|
||
|
||
# 配置字段
|
||
|
||
| 名称 | 数据类型 | 填写要求 | 默认值 | 描述 |
|
||
| -------- | -------- | -------- | -------- | -------- |
|
||
| status_code | number | 选填 | 200 | 自定义 HTTP 应答状态码 |
|
||
| headers | array of string | 选填 | - | 自定义 HTTP 应答头,key 和 value 用`=`分隔 |
|
||
| body | string | 选填 | - | 自定义 HTTP 应答 Body |
|
||
| enable_on_status | array of number | 选填 | - | 匹配原始状态码,生成自定义响应,不填写时,不判断原始状态码 |
|
||
|
||
# 配置示例
|
||
|
||
## Mock 应答场景
|
||
|
||
```yaml
|
||
status_code: 200
|
||
headers:
|
||
- Content-Type=application/json
|
||
- Hello=World
|
||
body: "{\"hello\":\"world\"}"
|
||
|
||
```
|
||
|
||
根据该配置,请求将返回自定义应答如下:
|
||
|
||
```text
|
||
HTTP/1.1 200 OK
|
||
Content-Type: application/json
|
||
Hello: World
|
||
Content-Length: 17
|
||
|
||
{"hello":"world"}
|
||
```
|
||
|
||
## 触发限流时自定义响应
|
||
|
||
```yaml
|
||
enable_on_status:
|
||
- 429
|
||
status_code: 302
|
||
headers:
|
||
- Location=https://example.com
|
||
```
|
||
|
||
触发网关限流时一般会返回 `429` 状态码,这时请求将返回自定义应答如下:
|
||
|
||
```text
|
||
HTTP/1.1 302 Found
|
||
Location: https://example.com
|
||
```
|
||
|
||
从而实现基于浏览器 302 重定向机制,将限流后的用户引导到其他页面,比如可以是一个 CDN 上的静态页面。
|
||
|
||
如果希望触发限流时,正常返回其他应答,参考 Mock 应答场景配置相应的字段即可。
|
||
|
||
## 对特定路由或域名开启
|
||
```yaml
|
||
# 使用 _rules_ 字段进行细粒度规则配置
|
||
_rules_:
|
||
# 规则一:按路由名称匹配生效
|
||
- _match_route_:
|
||
- route-a
|
||
- route-b
|
||
body: "{\"hello\":\"world\"}"
|
||
# 规则二:按域名匹配生效
|
||
- _match_domain_:
|
||
- "*.example.com"
|
||
- test.com
|
||
enable_on_status:
|
||
- 429
|
||
status_code: 200
|
||
headers:
|
||
- Content-Type=application/json
|
||
body: "{\"errmsg\": \"rate limited\"}"
|
||
```
|
||
此例 `_match_route_` 中指定的 `route-a` 和 `route-b` 即在创建网关路由时填写的路由名称,当匹配到这两个路由时,将使用此段配置;
|
||
此例 `_match_domain_` 中指定的 `*.example.com` 和 `test.com` 用于匹配请求的域名,当发现域名匹配时,将使用此段配置;
|
||
配置的匹配生效顺序,将按照 `_rules_` 下规则的排列顺序,匹配第一个规则后生效对应配置,后续规则将被忽略。
|