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 規範,你必須使用 $\ 來表示 $