Spring Cloud Gateway 是 Spring Cloud 的一个全新项目,该项目是基于 Spring 5.0, Spring WebFlux 和 Project Reactor 等技术创建的,用于构建
API 网关。
以下是一些常见的 Spring Cloud Gateway 配置说明:
- 路由配置
 
路由是网关最基本的部分,路由配置通过 spring.cloud.gateway.routes 来进行。
spring:
  cloud:
    gateway:
      routes:
        - id: after_route
          uri: https://example.org
          predicates:
            - Path=/foo/**
在这个例子中,我们定义了一个路由,这个路由的 ID 是 after_route,这个路由会把匹配到 /foo/** 这个路径的请求都转发到 https://example.org。
- 过滤器配置
 
过滤器是网关的另一个核心部分,过滤器配置通过 spring.cloud.gateway.default-filters 来进行。
spring:
  cloud:
    gateway:
      default-filters:
        - AddResponseHeader=X-Response-Default-Foo, Bar
在这个例子中,我们定义了一个过滤器,这个过滤器会给所有通过网关的响应添加一个名为 X-Response-Default-Foo 的响应头,值为 Bar。
- 路径重写
 
在某些情况下,我们可能需要在请求被转发到后端服务之前重写请求的路径,这可以通过 Spring Cloud Gateway 的 Path 路径重写过滤器来实现。
spring:
  cloud:
    gateway:
      routes:
        - id: path_rewrite
          uri: https://example.org
          predicates:
            - Path=/foo/**
          filters:
            - RewritePath=/foo/(?<segment>.*), /$\{segment}
在这个例子中,我们定义了一个路由,这个路由会把匹配到 /foo/** 这个路径的请求进行路径重写后再转发到 https://example.org。
- 权限校验
 
在某些情况下,我们可能需要在请求被转发到后端服务之前进行权限校验,这可以通过自定义 GatewayFilter 来实现。
@Component
public class AuthFilter implements GatewayFilter, Ordered {
    @Override
    public Mono<Void> filter(ServerWebExchange exchange, GatewayFilterChain chain) {
        // 这里可以添加权限校验的逻辑
        // 如果校验通过则调用 chain.filter(exchange),继续执行后续的过滤器和转发请求
        // 如果校验不通过则返回错误响应或者抛出异常
        return chain.filter(exchange);
    }
 
    @Override
    public int getOrder() {
        // 定义过滤器的顺序,数字越小,优先级越高
        return -1;
    }
}
在这个例子中,我们定义了一个 GatewayFilter,这个 GatewayFilter 会在请求被转发前进行权限校验。
以上就是一些常见的 Spring Cloud Gateway 配置说明和示例代码。