自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

談?wù)勀銓W(wǎng)關(guān)過濾器的理解?

開發(fā) 前端
在 Spring Cloud Gateway 中,過濾器是在請求到達目標(biāo)服務(wù)之前或之后,執(zhí)行某些特定操作的一種機制。例如,它可以實現(xiàn)對傳入的請求進行驗證、修改、日志記錄、身份驗證、流量控制等各種功能。

在 Spring Cloud Gateway 中,過濾器是在請求到達目標(biāo)服務(wù)之前或之后,執(zhí)行某些特定操作的一種機制。例如,它可以實現(xiàn)對傳入的請求進行驗證、修改、日志記錄、身份驗證、流量控制等各種功能。

在 Spring Cloud Gateway 中,過濾器總共分為以下兩大類:

  1. 局部過濾器:只作用于某一個路由(route)。
  2. 全局過濾器:對所有的路由都有效。
  • 內(nèi)置全局過濾器:Spring Cloud Gateway 自帶的 30+ 過濾器,詳情請訪問:https://docs.spring.io/spring-cloud-gateway/docs/current/reference/html/#gatewayfilter-factories
  • 自定義全局過濾器:開發(fā)者自行實現(xiàn)的過濾器。

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 內(nèi)置過濾器之一。

2.全局過濾器

全局過濾器會對當(dāng)前網(wǎng)關(guān)中的所有路由都生效。

(1)內(nèi)置全局過濾器

Spring Cloud Gateway 中的內(nèi)置全局過濾器配置如下:

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”就是全局內(nèi)置過濾器,它對所有的路由(route)有效,它的含義是在輸出對象 Response 中添加 Header 信息,key 為“gateway-default-filters”,value 為“www.javacn.site”。

(2)自定義全局過濾器

Spring Cloud Gateway 中自定義全局過濾器的實現(xiàn)是,定義一個類,使用 @Component 注解將其存入 IoC 容器,然后再實現(xiàn) GlobalFilter 接口,重寫 filter 方法,在 filter 中寫自己的過濾方法即可,具體實現(xiàn)如下:

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();
        // 業(yè)務(wù)邏輯代碼
        if(request.getQueryParams().getFirst("auth")==null){
            // 權(quán)限有問題返回,并結(jié)束執(zhí)行
            response.setStatusCode(HttpStatus.FORBIDDEN);
            return response.setComplete();
        }
        // 此步驟正常,執(zhí)行下一步
        return chain.filter(exchange);
    }

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

以上代碼是驗證請求參數(shù)中是否有“auth”參數(shù),如果沒有的話就認為未登錄,調(diào)用“response.setComplete()”終止繼續(xù)執(zhí)行,反之則認為已經(jīng)登錄,可以執(zhí)行后續(xù)流程了,使用“chain.filter(exchange)”來實現(xiàn)。

責(zé)任編輯:姜華 來源: 磊哥和Java
相關(guān)推薦

2024-04-03 08:08:15

謂詞網(wǎng)關(guān)開發(fā)

2022-06-30 09:10:33

NoSQLHBaseRedis

2023-11-28 12:25:02

多線程安全

2022-05-13 08:23:07

Zuul微服務(wù)Zuul過濾器

2021-07-05 15:22:03

Servlet過濾器客戶端

2024-09-18 10:08:37

2024-01-05 09:04:35

隆過濾器數(shù)據(jù)結(jié)構(gòu)哈希函數(shù)

2022-09-19 07:57:59

云服務(wù)互聯(lián)網(wǎng)基礎(chǔ)設(shè)施

2024-09-20 05:46:00

2024-09-11 16:49:55

2009-06-18 10:13:00

Hibernate過濾

2009-07-08 17:33:37

Servlet過濾器

2025-02-08 17:30:00

布隆過濾器數(shù)據(jù)結(jié)構(gòu)

2024-11-04 08:45:48

布隆過濾器元數(shù)據(jù)指紋值

2009-07-08 15:30:56

Servlet過濾器

2009-07-08 16:07:04

Servlet過濾器配

2009-09-29 13:55:23

Hibernate設(shè)置

2009-07-14 09:09:08

Swing模型過濾器

2011-06-29 16:14:59

Qt 事件 過濾器

2022-08-14 07:14:50

Kafka零拷貝
點贊
收藏

51CTO技術(shù)棧公眾號