面试官:SpringCloudGateway过滤器类型有哪些?

开发 前端
在 Spring Cloud Gateway 中,过滤器是在请求到达目标服务之前或之后,执行某些特定操作的一种机制。例如,它可以实现对传入的请求进行验证、修改、日志记录、身份验证、流量控制等各种功能。

在 Spring Cloud Gateway 中,过滤器总共分为以下两大类:

  • 局部过滤器:只作用于某一个路由(route)。
  • 全局过滤器:对所有的路由都有效。
  1. 内置全局过滤器:Spring Cloud Gateway 自带的 30+ 过滤器,详情请访问:https://docs.spring.io/spring-cloud-gateway/docs/current/reference/html/#gatewayfilter-factories
  2. 自定义全局过滤器:开发者自行实现的过滤器。

1、局部过滤器

Spring Cloud Gateway 中的局部过滤器配置如下:

spring:
  cloud:
    gateway:
      routes:
        - id: userservice
          uri: http://192.168.1.7:56628
          predicates:
            - Path=/user/**
          filters:
            - AddResponseHeader=gateway-flag, javacn.site

以上过滤器的含义是在输出对象 Response 中添加 Header 信息,key 为“gateway-flag”,value 为“javacn.site”。

PS:AddResponseHeader 也是 Gateway 内置过滤器之一。

2、全局过滤器

全局过滤器会对当前网关中的所有路由都生效。

(1)内置全局过滤器

Spring Cloud Gateway 中的内置全局过滤器配置如下:

spring:
  cloud:
    gateway:
      routes:
        - id: userservice
          uri: http://192.168.1.7:51627
          predicates:
          - Weight=group1,50
        - id: userservice2
          uri: http://192.168.1.7:56628
          predicates:
            - Weight=group1,50
          filters:
            - AddResponseHeader=gateway-flag, javacn.site
      default-filters:
        - AddResponseHeader=gateway-default-filters, www.javacn.site

其中的“default-filters”就是全局内置过滤器,它对所有的路由(route)有效,它的含义是在输出对象 Response 中添加 Header 信息,key 为“gateway-default-filters”,value 为“www.javacn.site”。

(2)自定义全局过滤器

Spring Cloud Gateway 中自定义全局过滤器的实现是,定义一个类,使用 @Component 注解将其存入 IoC 容器,然后再实现 GlobalFilter 接口,重写 filter 方法,在 filter 中写自己的过滤方法即可,具体实现如下:

import org.springframework.cloud.gateway.filter.GatewayFilterChain;
import org.springframework.cloud.gateway.filter.GlobalFilter;
import org.springframework.core.Ordered;
import org.springframework.http.HttpStatus;
import org.springframework.http.server.reactive.ServerHttpRequest;
import org.springframework.http.server.reactive.ServerHttpResponse;
import org.springframework.stereotype.Component;
import org.springframework.web.server.ServerWebExchange;
import reactor.core.publisher.Mono;

@Component
public class AuthFilter implements GlobalFilter, Ordered {
    @Override
    public Mono<Void> filter(ServerWebExchange exchange, GatewayFilterChain chain) {
        // 得到 request、response 对象
        ServerHttpRequest request = exchange.getRequest();
        ServerHttpResponse response = exchange.getResponse();
        // 业务逻辑代码
        if(request.getQueryParams().getFirst("auth")==null){
            // 权限有问题返回,并结束执行
            response.setStatusCode(HttpStatus.FORBIDDEN);
            return response.setComplete();
        }
        // 此步骤正常,执行下一步
        return chain.filter(exchange);
    }

    @Override
    public int getOrder() {
        // 此值越小越早执行
        return 1;
    }
}

以上代码是验证请求参数中是否有“auth”参数,如果没有的话就认为未登录,调用“response.setComplete()”终止继续执行,反之则认为已经登录,可以执行后续流程了,使用“chain.filter(exchange)”来实现。

责任编辑:姜华 来源: Java中文社群
相关推荐

2023-02-20 07:19:14

2024-09-25 17:44:08

2020-09-14 12:46:25

过滤器拦截器Filter

2023-02-20 08:08:48

限流算法计数器算法令牌桶算法

2024-03-07 17:21:12

HotSpotJVMHot Code

2021-05-10 08:01:12

BeanFactoryFactoryBean容器

2024-02-26 14:07:18

2024-04-19 00:00:00

计数器算法限流算法

2024-03-12 14:36:44

微服务HTTPRPC

2021-07-05 15:22:03

Servlet过滤器客户端

2021-08-11 08:53:23

Git命令面试

2024-01-05 09:04:35

隆过滤器数据结构哈希函数

2021-09-09 07:21:26

TypeScript 高级类型

2024-11-04 08:45:48

布隆过滤器元数据指纹值

2021-08-02 08:34:20

React性能优化

2021-09-30 07:57:13

排序算法面试

2021-06-02 09:42:29

Node. js全局对象

2021-07-01 07:51:45

React事件绑定

2021-05-27 05:37:10

HTTP请求头浏览器

2024-07-26 08:10:10

点赞
收藏

51CTO技术栈公众号