RewriteResponseHeader Filter

RewriteResponseHeader 过滤器采用 nameregexpreplacement 参数。它使用 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 规范,你必须使用 $\ 来表示 $