跳到主要内容

AddRequestHeadersIfNotPresent 过滤器

DeepSeek V3 中英对照 AddRequestHeadersIfNotPresent Filter AddRequestHeadersIfNotPresent Filter

AddRequestHeadersIfNotPresent 过滤器接受一组由冒号分隔的 namevalue 键值对。以下示例配置了一个 AddRequestHeadersIfNotPresent 过滤器:

spring:
cloud:
gateway:
mvc:
routes:
- id: add_request_headers_route
uri: https://example.org
filters:
- AddRequestHeadersIfNotPresent=X-Request-Color-1:blue,X-Request-Color-2:green
yaml
import static org.springframework.cloud.gateway.server.mvc.filter.BeforeFilterFunctions.addRequestHeadersIfNotPresent;
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> gatewayRouterFunctionsAddReqHeader() {
return route(GET("/red"), http("https://example.org"))
.before(addRequestHeadersIfNotPresent("X-Request-Color-1:blue","X-Request-Color-2:green"));
}
}
java

此列表为所有匹配的请求向下游请求的头部添加了 2 个头部 X-Request-Color-1:blueX-Request-Color-2:green。这与 AddRequestHeader 的工作方式类似,但与 AddRequestHeader 不同的是,它仅在头部不存在时才会添加。否则,将发送客户端请求中的原始值。

此外,要设置多值标头,请多次使用标头名称,例如 addRequestHeadersIfNotPresent("X-Request-Color-1:blue","X-Request-Color-1:green")

AddRequestHeadersIfNotPresent 还支持用于匹配路径或主机的 URI 变量。URI 变量可以在值中使用,并在运行时展开。以下示例配置了一个使用变量的 AddRequestHeadersIfNotPresent 过滤器:

@Configuration
class RouteConfiguration {

@Bean
public RouterFunction<ServerResponse> gatewayRouterFunctionsAddReqHeader() {
return route(GET("/red/{segment}"), http("https://example.org"))
.before(addRequestHeadersIfNotPresent("X-Request-red", "blue-{segment}"));
}
}
java
spring:
cloud:
gateway:
routes:
- id: add_request_header_route
uri: https://example.org
predicates:
- Path=/red/{segment}
filters:
- AddRequestHeadersIfNotPresent=X-Request-Red:Blue-{segment}
yaml