RewriteResponseHeader 过滤器

RewriteResponseHeader 过滤器接受 nameregexpreplacement 参数。它使用 Java 正则表达式灵活地重写响应头的值。以下示例配置了一个 RewriteResponseHeader 过滤器:

application.yml
spring:
  cloud:
    gateway:
      mvc:
        routes:
        - id: rewriteresponseheader_route
          uri: https://example.org
          predicates:
          - Path=/**
          filters:
          - RewriteResponseHeader=X-Response-Red, password=[^&]+, password=***
GatewaySampleApplication.java
import static org.springframework.cloud.gateway.server.mvc.filter.AfterFilterFunctions.rewriteResponseHeader;
import static org.springframework.cloud.gateway.server.mvc.filter.BeforeFilterFunctions.uri;
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())
            .before(uri("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 规范,你必须使用 $\ 来表示 $