Java之Springcloud Gateway內(nèi)置路由案例講解
Spring Cloud Gateway路由匹配是Spring WebFlux基礎(chǔ)功能的一部分,在Spring Cloud Gateway中內(nèi)置了很多路由斷言工廠類。不同的斷言工廠類針對(duì)HTTP請(qǐng)求的不同屬性。多個(gè)斷言工廠類可以使用邏輯“and”進(jìn)行組合使用。
4.1 After Route Predicate Factory
這個(gè)Predicate工廠的實(shí)現(xiàn)類是AfterRoutePredicateFactory,使用一個(gè)時(shí)間參數(shù),如果當(dāng)前請(qǐng)求的時(shí)間在配置的趕時(shí)間之后,此斷言才會(huì)返回true。在application.yml中如下配置所示:
spring:
cloud:
gateway:
routes:
- id: after_route
uri: http://www.test111.com # 如果斷言返回true,路由到的URI
predicates:
- After=2017-01-20T17:42:47.789-07:00[America/Denver]
注意這個(gè)類使用的時(shí)間類是ZonedDateTime,表示ISO-8601日歷系統(tǒng)中具有時(shí)區(qū)的日期時(shí)間,所以在application.yml中的時(shí)間配置格式只能是:2017-01-20T17:42:47.789-07:00[America/Denver],字符串的時(shí)間格式轉(zhuǎn)化為ZonedDateTime使用的是StringToZonedDateTimeConverter類。如果想使用其它的時(shí)間格式,得需要自己實(shí)現(xiàn)一個(gè)單獨(dú)的轉(zhuǎn)化類了。通過源碼中的測(cè)試?yán)涌梢钥吹?,如果?qǐng)求在配置的時(shí)間之前,網(wǎng)關(guān)會(huì)返回404,如果在配置的時(shí)間之后,網(wǎng)關(guān)路由成功到www.test111.com 網(wǎng)站。
這里簡(jiǎn)單說一下spring.cloud.gateway.routes的配置,它對(duì)應(yīng)的是一個(gè)List列表,List列表存儲(chǔ)的對(duì)象類型是RouteDefinition,這是一個(gè)路由的定義類。id是在這個(gè)List列表中所有的路由定義中必須唯一,可以隨便定義。在RouteDefinition聲明的字段,在application.yml中的spring.cloud.gateway.routes中都可以配置。
4.2 Before Route Predicate Factory
這個(gè)Predicate工廠的實(shí)現(xiàn)類是BeforeRoutePredicateFactory,它和AfterRoutePredicateFactory的實(shí)現(xiàn)基本上是一致的,在application.yml中的配置如下所示:
spring:
cloud:
gateway:
routes:
- id: before_route
uri: http://www.test111.com # 路由到的URI
predicates:
- Before=2017-01-20T17:42:47.789-07:00[America/Denver]
如果當(dāng)前請(qǐng)求的時(shí)間在配置的時(shí)間之前,此斷言返回true,網(wǎng)關(guān)將請(qǐng)求路由到www.test111.com網(wǎng)站。否則,返回404。
4.3 Between Route Predicate Factory
這個(gè)Predicate的工廠實(shí)現(xiàn)類是BetweenRoutePredicateFactory,它有兩個(gè)參數(shù),datatime1,datetime2,在application.yml中的配置如下:
spring:
cloud:
gateway:
routes:
- id: between_route
uri: http://www.test111.com
predicates:
- Between=2017-01-20T17:42:47.789-07:00[America/Denver], 2017-01-21T17:42:47.789-07:00[America/Denver]
當(dāng)請(qǐng)求網(wǎng)關(guān)的時(shí)間在datatime1之后,在datetim2之前時(shí),這個(gè)斷言返回true,會(huì)將請(qǐng)求路由到www.test111.com網(wǎng)站。這個(gè)斷言對(duì)于維護(hù)一個(gè)時(shí)間窗口很有用。比如限制在基某段時(shí)間內(nèi)開啟的活動(dòng),非這個(gè)時(shí)間段不可以訪問等。
4.4 Cookie Route Predicate Factory
這個(gè)Predicate工廠的實(shí)現(xiàn)類是CookieRoutePredicateFactory,它有兩個(gè)參數(shù),一個(gè)是name,另一個(gè)是正則表達(dá)式。在application.,yml中的配置如下所示:
spring:
cloud:
gateway:
routes:
- id: cookie_route
uri: http://www.test111.com
predicates:
- Cookie=username, wgslcuky
如果請(qǐng)求的Cookie中有name的值,并且根據(jù)name取出的值都匹配配置的正則表達(dá)式,這個(gè)斷方就返回true,會(huì)將請(qǐng)求路由到http://www.test111.com網(wǎng)站。上面的配置就是表示Cookie中username的值是wgslucky時(shí),斷言返回true.
4.5 Header Route Predicate Factory
這個(gè)Predicate工廠的實(shí)現(xiàn)類是HeaderRoutePredicateFactory,它有兩個(gè)參數(shù),一個(gè)是name,另一個(gè)是正則表達(dá)式。在application.yml中的配置如下所示:
spring:
cloud:
gateway:
routes:
- id: header_route
uri: http://www.test111.com
predicates:
- Header=X-Request-Id, \d+
如果請(qǐng)求的Header里面有name的值,并且它的值與配置的正則表達(dá)式匹配,則斷言返回true,如果沒有配置正則表達(dá)式的值,斷言也是返回true(斷方只檢測(cè)帶正則表達(dá)式的配置),將會(huì)把請(qǐng)求路由到http://www.test111.com網(wǎng)站。上面的配置示例表示Header中必須有X-Request-Id,且它的值必須是數(shù)字。
4.6 Host Route Predicate Factory
這個(gè)Predicate的工廠的實(shí)現(xiàn)類是HostRoutePredicateFactory,這有一個(gè)參數(shù),這個(gè)參數(shù)是一人List列表,它可以包含多個(gè)主機(jī)名字匹配的樣式。它遵循Ant的樣式風(fēng)格,以點(diǎn)(.)分隔。在application.yml中的配置如下所示:
spring:
cloud:
gateway:
routes:
- id: host_route
uri: http://www.test111.com
predicates:
- Host=**.somehost.org,**.anotherhost.org,{sub}.myhost.org
上面示例中Host對(duì)應(yīng)的URI模板變量同樣也支持{sub}.myhost.org格式的配置。如果請(qǐng)求的Header中的Host的值是www.sonmehost.org,abc.somehost.org,api.anotherhost.org,這個(gè)斷言就會(huì)返回true,將請(qǐng)求路由到http://www.test111.com網(wǎng)站。
在斷方工廠中會(huì)提取上面配置中Host對(duì)應(yīng)的URI模板變量(比如上面的sub),把匹配的URI放到一個(gè)Map中,這個(gè)Map會(huì)被添加到ServerWebExchange.getAttributes(ServerWebExchangeUtils.URI_TEMPLATE_VARIABLES_ATTRIBUTE)的屬性集中。可以在后面的Gateway Filter工廠類使用。
注意,在配置Host的時(shí)候,如果Host不是80端口,在配置的時(shí)候也需要添加上端口。如:localhost:8080
4.7 Method Route Predicate Factory
這個(gè)Predicate的實(shí)現(xiàn)類是MethodRoutePredicateFactory,它有一個(gè)參數(shù):指定的Http方法名。在application.yml中的配置如下所示:
spring:
cloud:
gateway:
routes:
- id: method_route
uri: http://www.test111.com
predicates:
- Method=GET
如果這個(gè)請(qǐng)求的方法名是GET,斷言將返回true,將請(qǐng)求路由到http://www.test111.com網(wǎng)站。
4.8 Path Route Predicate Factory
這個(gè)Predicate的實(shí)現(xiàn)類是PathRoutePredicateFactory,它有兩個(gè)參數(shù),一個(gè)是匹配樣式列表,另一個(gè)是boolean值,表示是否匹配分隔線。在application.yml中的配置好下所示:
spring:
cloud:
gateway:
routes:
- id: path_route
uri: http://www.test111.com
predicates:
- Path=/foo/{segment},/bar/{segment}
如果請(qǐng)求的URI中的路徑是/foo/1,/foo/bar或/bar/baz,這個(gè)斷言將返回true,會(huì)將請(qǐng)求路由到http://www.test111.com網(wǎng)站。這個(gè)斷言工廠將會(huì)提取配置的URI格式中的變量(比如上面配置的segment),并將它轉(zhuǎn)化為Map,替換掉ServerWebExchange.getAttributes(ServerWebExchangeUtils.URI_TEMPLATE_VARIABLES_ATTRIBUTE)中的值。這個(gè)值可以在GatewayFilter工廠中使用。有一個(gè)方法可以方便的訪問這些值,如下面代碼所示:
Map<String, String> uriVariables = ServerWebExchangeUtils.getPathPredicateVariables(exchange);
String segment = uriVariables.get("segment");
4.9 Query Route Predicate Factory
這個(gè)是參數(shù)路由斷言工廠,它的實(shí)現(xiàn)類是QueryRoutePredicateFactory,它有兩個(gè)參數(shù),一個(gè)是參數(shù)(param),這個(gè)是必須的,另一個(gè)是可選參數(shù),是一個(gè)正則表達(dá)式。在application.yml中不帶正則的配置如下所示:
spring:
cloud:
gateway:
routes:
- id: query_route
uri: http://www.test111.com
predicates:
- Query=baz
如果請(qǐng)求的參數(shù)中包含baz參數(shù),斷言將返回true,并將請(qǐng)求路由到http://www.test111.com網(wǎng)站。帶正則表達(dá)式的配置如下所示:
spring:
cloud:
gateway:
routes:
- id: query_route
uri: http://example.org
predicates:
- Query=foo, ba.
如果請(qǐng)求的參數(shù)中包含foo,且它的值匹配ba.,斷言將返回true,并將請(qǐng)求路徑到http://www.test111.com網(wǎng)著。
4.10 RemoteAddr Route Predicate Factory
這個(gè)是遠(yuǎn)程地址路由斷言工廠,它的實(shí)現(xiàn)類是RemoteAddrRoutePredicateFactory,它有一個(gè)List列表的參數(shù),這些參數(shù)是CIDR-notation(IPv4和IPv6)的地址字符串,比如192.168.0.1/16(192.168.0.1是ip地址,16是一個(gè)子網(wǎng)掩碼)。在application.yml中的配置如下所示:
spring:
cloud:
gateway:
routes:
- id: remoteaddr_route
uri: http://www.test111.com
predicates:
- RemoteAddr=192.168.1.1/24
如果請(qǐng)求的客戶端的ip地址是192.168.1.1到192.168.1.24的范圍,此斷言返回true,并將請(qǐng)求路由到http://www.test111.com網(wǎng)站。比如192.168.1.10。
4.10.1修改遠(yuǎn)程地址的解析方式
默認(rèn)情況下,RemoteAddrRoutePredicateFactory中用到的遠(yuǎn)程客戶端的IP地址是從請(qǐng)求中獲取的,但是,如果Spring Cloud Gateway是部署在一個(gè)代理服務(wù)之后的話,這可能就匹配不到真實(shí)的客戶端IP地址。這樣的話,你可以實(shí)現(xiàn)RemoteAddressResolver接口,自定義一個(gè)IP地址的解析方式。在Spring Cloud Gateway中有一個(gè)非默認(rèn)的遠(yuǎn)程IP地址解析器XForwardedRemoteAddressResolver,它是基于X-Forwarded-For header實(shí)現(xiàn)的。XForwardedRemoteAddressResolver有兩個(gè)靜態(tài)的構(gòu)造方法,可以用于不同的安全策略:XForwardedRemoteAddressResolver::trustAll方法返回一個(gè)RemoteAddressResolver實(shí)例,它返回從X-Forwarded-For header獲取到的第一個(gè)IP地址。這種方式容易受到欺騙攻擊,惡意的客戶端可以給X-Forwarded-For設(shè)置一個(gè)初始化的值,這個(gè)值對(duì)于解析器來說是可以接受的。XForwardedRemoteAddressResolver::maxTrustedIndex需要一個(gè)索引值做為參數(shù),這個(gè)值和Spring Cloud Gateway前面受信任的代理設(shè)備數(shù)量相關(guān)。比如,如果Spring Cloud Gateway只可以通過HAPoxy訪問,那么maxTrustedIndex應(yīng)該設(shè)置為1,如果需要通過兩個(gè)受信任的設(shè)備訪問,那么這個(gè)值應(yīng)該設(shè)置為2。比如在Header中的X-Forwarded-For值如下所示:
X-Forwarded-For: 0.0.0.1, 0.0.0.2, 0.0.0.3
那么maxTrustedIndex的值與下面的遠(yuǎn)程相對(duì)應(yīng):
| maxTrustedIndex | result |
| [Integer.MIN_VALUE,0] | (invalid, IllegalArgumentException during initialization |
| 1 | 0.0.0.3 |
| 2 | 0.0.0.2 |
| 3 | 0.0.0.1 |
| [4, Integer.MAX_VALUE] | 0.0.0.1 |
如下面代碼所示:
RemoteAddressResolver resolver = XForwardedRemoteAddressResolver
.maxTrustedIndex(1);
...
.route("direct-route",
r -> r.remoteAddr("10.1.1.1", "10.10.1.1/24")
.uri("https://downstream1")
.route("proxied-route",
r -> r.remoteAddr(resolver, "10.10.1.1", "10.10.1.1/24")
.uri("https://downstream2")
)
項(xiàng)目源碼地址:https://gitee.com/wgslucky/SpringCloud
到此這篇關(guān)于Java之Springcloud Gateway內(nèi)置路由案例講解的文章就介紹到這了,更多相關(guān)Java之Springcloud Gateway內(nèi)置路由內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Java編程實(shí)現(xiàn)月食簡(jiǎn)單代碼分享
這篇文章主要介紹了Java編程實(shí)現(xiàn)月食簡(jiǎn)單代碼分享,程序很簡(jiǎn)單,喜歡的朋友可以拿過去玩玩。2017-11-11
深入解析Spring?AI框架如何在Java應(yīng)用中實(shí)現(xiàn)智能化交互的關(guān)鍵
本文詳細(xì)介紹了SpringAI框架在Java應(yīng)用中的應(yīng)用,包括實(shí)體類映射、函數(shù)回調(diào)等核心功能的實(shí)現(xiàn),通過源碼分析,幫助開發(fā)者更好地理解和使用這些高級(jí)特性,提升業(yè)務(wù)效率,感興趣的朋友跟隨小編一起看看吧2024-11-11
maven如何打包動(dòng)態(tài)環(huán)境變量(包括啟動(dòng)腳本)
這篇文章主要介紹了maven如何打包動(dòng)態(tài)環(huán)境變量(包括啟動(dòng)腳本)問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-04-04
Mybatis?MappedStatement類核心原理詳解
這篇文章主要介紹了Mybatis?MappedStatement類,mybatis的mapper文件最終會(huì)被解析器,解析成MappedStatement,其中insert|update|delete|select每一個(gè)標(biāo)簽分別對(duì)應(yīng)一個(gè)MappedStatement2022-11-11
Java 實(shí)戰(zhàn)項(xiàng)目錘煉之網(wǎng)上圖書館管理系統(tǒng)的實(shí)現(xiàn)流程
讀萬卷書不如行萬里路,只學(xué)書上的理論是遠(yuǎn)遠(yuǎn)不夠的,只有在實(shí)戰(zhàn)中才能獲得能力的提升,本篇文章手把手帶你用Java+jsp+servlet+mysql+ajax實(shí)現(xiàn)一個(gè)網(wǎng)上圖書館管理系統(tǒng),大家可以在過程中查缺補(bǔ)漏,提升水平2021-11-11
SpringBoot自動(dòng)配置Quartz的實(shí)現(xiàn)步驟
本文主要介紹了SpringBoot自動(dòng)配置Quartz的實(shí)現(xiàn)步驟,文中通過示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2021-11-11
詳解java調(diào)用存儲(chǔ)過程并封裝成map
這篇文章主要介紹了詳解java調(diào)用存儲(chǔ)過程并封裝成map的相關(guān)資料,希望通過本文能幫助到大家實(shí)現(xiàn)這樣的功能,需要的朋友可以參考下2017-09-09
Spring Cloud Ribbon實(shí)現(xiàn)客戶端負(fù)載均衡的示例
本篇文章主要介紹了Spring Cloud Ribbon實(shí)現(xiàn)客戶端負(fù)載均衡的示例,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2018-02-02
Java泛型與數(shù)據(jù)庫應(yīng)用實(shí)例詳解
這篇文章主要介紹了Java泛型與數(shù)據(jù)庫應(yīng)用,結(jié)合實(shí)例形式詳細(xì)分析了java繼承泛型類實(shí)現(xiàn)增刪改查操作相關(guān)實(shí)現(xiàn)技巧,需要的朋友可以參考下2019-08-08

