1. 概述
#
1.1 插件名称- 响应修改插件
#
1.2 适用场景- 需要对接口的响应头部参数、响应HTTP状态码或响应体进行修改的场景
#
1.3 插件功能- 修改HTTP响应状态码
- 添加、设置、覆盖或者移除响应头部参数
- 添加、覆盖或者移除响应体参数
#
1.4 插件代码- 核心模块
shenyu-plugin-modify-response
- 核心类
org.apache.shenyu.plugin.modify.response.ModifyResponsePlugin
#
1.5 添加自哪个 shenyu 版本- 2.4.0
2. 如何使用插件
#
2.1 插件使用流程图#
2.2 导入 pom- 在网关的
pom.xml
文件中添加插件 maven 配置。
<dependency> <groupId>org.apache.shenyu</groupId> <artifactId>shenyu-spring-boot-starter-gateway</artifactId> <version>${project.version}</version> </dependency>
#
2.3 启用插件- 在
shenyu-admin
--> 基础配置 --> 插件管理 -->modifyResponse
设置为开启。
#
2.4 配置插件- 选择器和规则设置,请参考:选择器和规则管理。
shenyu-admin
插件列表 -->HttpProcess
-->modifyResponse
,先添加选择器,然后添加规则:- 添加选择器
- 添加规则
#
2.5 示例客户端项目可以直接使用 shenyu-examples-http,注意该示例项目的contextPath
为/http
,需要在shenyu-admin
和shenyu-gateway
启动完成后启动。
#
2.5.1 示例 设置HTTP响应状态码本地部署启动 admin 和网关#
2.5.1.1 参考#
2.5.1.2 参考 2.2 导入 pom 并重启网关#
2.5.1.3 参考 2.3 启用插件#
2.5.1.4 参考 2.4 配置插件规则配置插件规则:
#
2.5.1.5 接口调用#
2.5.2 示例 修改响应头部参数本地部署启动 admin 和网关#
2.5.2.1 参考#
2.5.2.2 参考 2.2 导入 pom 并重启网关#
2.5.2.3 参考 2.3 启用插件#
2.5.2.4 参考 2.4 配置插件规则#
2.5.2.5 接口调用#
2.5.3 示例 修改响应体本地部署启动 admin 和网关#
2.5.3.1 参考#
2.5.3.2 参考 2.2 导入 pom 并重启网关#
2.5.3.3 参考 2.3 启用插件#
2.5.3.4 参考 2.4 配置插件规则配置插件规则:
#
2.5.3.5 接口调用#
3. 如何禁用插件- 在
shenyu-admin
--> 基础配置 --> 插件管理 -->modifyResponse
设置为禁用。
#
4. 插件规则参数列表对于HTTP响应状态码:
statusCode
: 修改响应状态码
对于HTTP响应头部参数:
addHeaders
: 添加响应头部参数,键值对形式setHeaders
: 设置响应头部参数,键值对形式replaceHeaderKeys
: 替换响应头部参数,其中key
参数为需要被替换的key
,value
参数为替换后的值removeHeaderKeys
: 移除响应头部参数,其中key
参数为需要被移除的key
对于HTTP响应体:
addBodyKeys
: 添加响应内容replaceBodyKeys
: 替换响应内容,其中key
参数为需要被替换的key
,value
参数为替换后的值removeBodyKeys
: 移除响应内容,其中key
参数为需要被移除的key
修改响应体是基于JSONPath
实现的,$.
代表根目录。对于下面的配置:
插件开启前,响应内容为:
{ "id": 3, "name": "hello world findById"}
插件开启后,响应内容为:
{ "id2": 3, "add": "4"}