猜你喜歡
更多>在Spring Cloud Gateway中,過濾器的執(zhí)行順序?qū)τ趯崿F(xiàn)請求處理流程的正確性和效率至關重要。Spring Cloud Gateway中的過濾器分為全局過濾器和局部過濾器兩種類型,不同類型的過濾器在執(zhí)行順序上有所不同。
全局過濾器執(zhí)行順序
全局過濾器是指在所有路由規(guī)則中都會執(zhí)行的過濾器,可以用于實現(xiàn)一些全局性的功能,如請求的日志記錄、響應頭信息的設置等。Spring Cloud Gateway提供了一些內(nèi)置的全局過濾器,如請求路徑的重寫、請求日志的記錄等。在Spring Cloud Gateway中,全局過濾器的執(zhí)行順序是由GatewayFilterAdapter的ORDER常量值確定的,該常量值為-2147483648,表示全局過濾器將在所有的局部過濾器之前執(zhí)行。
(資料圖片僅供參考)
局部過濾器執(zhí)行順序
局部過濾器是指只在特定路由規(guī)則中才會執(zhí)行的過濾器,可以用于實現(xiàn)一些特定的功能,如請求鑒權(quán)、請求轉(zhuǎn)發(fā)等。Spring Cloud Gateway中的局部過濾器可以通過自定義過濾器工廠類來實現(xiàn),該工廠類需要繼承AbstractGatewayFilterFactory抽象類,并實現(xiàn)其中的apply方法和泛型參數(shù)指定配置類。在Spring Cloud Gateway中,局部過濾器的執(zhí)行順序是由配置文件中的filters屬性確定的,該屬性可以通過spring.cloud.gateway.routes.filters參數(shù)進行配置,不同的過濾器在列表中的位置就決定了它們的執(zhí)行順序。
以下是一個示例,其中定義了一個全局過濾器和兩個局部過濾器,演示了不同類型過濾器的執(zhí)行順序:
@Componentpublic class GlobalFilter implements GatewayFilter, Ordered { @Override public Mono filter(ServerWebExchange exchange, GatewayFilterChain chain) { System.out.println("GlobalFilter before..."); return chain.filter(exchange).then(Mono.fromRunnable(() -> { System.out.println("GlobalFilter after..."); })); } @Override public int getOrder() { return -1; }}@Componentpublic class LocalFilter1 extends AbstractGatewayFilterFactory { public LocalFilter1() { super(Config.class); } @Override public GatewayFilter apply(Config config) { return (exchange, chain) -> { System.out.println("LocalFilter1 before..."); return chain.filter(exchange).then(Mono.fromRunnable(() -> { System.out.println("LocalFilter1 after..."); })); }; } public static class Config { // 配置參數(shù) }}@Componentpublic class LocalFilter2 extends AbstractGatewayFilterFactory { public LocalFilter2() { super(Config.class); } @Override public GatewayFilter apply(Config config) { return (exchange, chain) -> { System.out.println("LocalFilter2 before..."); return chain.filter(exchange).then(Mono.fromRunnable(() -> { System.out.println("LocalFilter2 after..."); })); }; } public static class Config { // 配置參數(shù) }}
在這個示例中,我們定義了一個全局過濾器GlobalFilter和兩個局部過濾器LocalFilter1和LocalFilter2。其中,GlobalFilter實現(xiàn)了GatewayFilter和Ordered接口,用于實現(xiàn)全局過濾器的邏輯。LocalFilter1和LocalFilter2都繼承了AbstractGatewayFilterFactory抽象類,并通過實現(xiàn)apply方法實現(xiàn)了局部過濾器的邏輯。在apply方法中,我們可以實現(xiàn)自己的過濾邏輯,并返回一個GatewayFilter對象。在GatewayFilter對象中,我們可以繼續(xù)調(diào)用chain.filter方法來執(zhí)行下一個過濾器,或者直接返回結(jié)果。這里我們使用Mono.fromRunnable方法來在請求結(jié)束時輸出一些信息。
在上述示例中,我們定義了全局過濾器和兩個局部過濾器。在執(zhí)行順序方面,由于全局過濾器的ORDER常量值最小,因此它會在所有的局部過濾器之前執(zhí)行。而在局部過濾器的執(zhí)行順序方面,它們的執(zhí)行順序是由配置文件中的filters屬性決定的,如下所示:
spring: cloud: gateway: routes: - id: example uri: http://example.org predicates: - Path=/example/** filters: - LocalFilter2 - LocalFilter1
在這個配置文件中,我們?yōu)閑xample路由規(guī)則指定了兩個局部過濾器,分別是LocalFilter2和LocalFilter1。在執(zhí)行順序方面,LocalFilter2將會先于LocalFilter1執(zhí)行,因為它們在filters列表中的位置是從前往后的。也就是說,請求先經(jīng)過LocalFilter2,再經(jīng)過LocalFilter1,最后再到達后端服務。
需要注意的是,在GatewayFilterChain中的filter方法調(diào)用中,如果其中一個過濾器返回了錯誤,那么整個請求處理過程會立即停止并返回錯誤。因此,在設計過濾器時需要格外小心,確保每個過濾器都不會拋出異常,以免影響整個系統(tǒng)的穩(wěn)定性。
此外,還有一些其他的過濾器類型,如:
Pre Filter:在請求被路由之前調(diào)用??梢杂脕韺崿F(xiàn)身份認證、IP過濾等邏輯。Post Filter:在請求被路由之后調(diào)用??梢杂脕韺崿F(xiàn)響應頭處理、日志記錄等邏輯。Error Filter:在請求處理過程中發(fā)生錯誤時調(diào)用。可以用來實現(xiàn)異常處理、錯誤日志記錄等邏輯。這些過濾器類型可以通過實現(xiàn)不同的接口來實現(xiàn)。例如,實現(xiàn)Ordered和GatewayFilter接口的就是Pre Filter和Global Filter類型的過濾器。而實現(xiàn)Ordered和WebFilter接口的則是Error Filter類型的過濾器。
標簽:
要聞
更多>新化:洋溪鎮(zhèn)撬動行業(yè)協(xié)會力量,助推農(nóng)村建筑安全、耕地保護和控違拆違工作良性開展
嘉峪關酒泉機場工程順利通過行業(yè)驗收 計劃9月7日復航
3連板大連熱電(600719.SH):擬籌劃的資產(chǎn)重組事項存在不確定性
昊華科技(600378)周評:本周跌3.29%,主力資金合計凈流出1578.27萬元
借力AI賦能全球創(chuàng)作者 萬興科技攜Wondershare Filmora亮相創(chuàng)作
全部真實業(yè)務系統(tǒng)!華為云展示盤古大模型行業(yè)應用