RewriteResponseHeader
Filter
RewriteResponseHeader
过滤器采用 name
、regexp
和 replacement
参数。它使用 Java 正则表达式以灵活的方式重写响应头值。以下示例配置了 RewriteResponseHeader
过滤器:
application.yml
spring:
cloud:
gateway:
mvc:
routes:
- id: rewriteresponseheader_route
uri: https://example.org
filters:
- RewriteResponseHeader=X-Response-Red, , password=[^&]+, password=***
GatewaySampleApplication.java
import static org.springframework.cloud.gateway.server.mvc.filter.AfterFilterFunctions.addResponseHeader;
import static org.springframework.cloud.gateway.server.mvc.handler.GatewayRouterFunctions.route;
import static org.springframework.cloud.gateway.server.mvc.handler.HandlerFunctions.http;
@Configuration
class RouteConfiguration {
@Bean
public RouterFunction<ServerResponse> gatewayRouterFunctionsRewriteResponseHeader() {
return route("rewriteresponseheader_route")
.GET("/**", http("https://example.org"))
.after(rewriteResponseHeader("X-Request-Red", "password=[^&]+", "password=***"))
.build();
}
}
对于 /42?user=ford&password=omg!what&flag=true
的头值,在下游请求后将其设为 /42?user=ford&password=*&flag=true
。由于 application.yml
中的 YAML 规范,你必须使用 $\
来表示 $
。