還在用 OpenFeign?來試試 SpringBoot3 中的這個(gè)新玩意!
年過完啦,松哥也已經(jīng)搬磚搬了三天了。
疫情放開后,今年這個(gè)年格外的輕松愜意,心中一種特別壓抑的東西被除去了,新聞中看到各地游人如織、西安大唐不夜城游人摩肩接踵,真的好像回到了 2019 年一樣,朋友圈中也都是喜氣洋洋,生活還是很美好的。
好久沒發(fā)技術(shù)文章了,最近回到工作地,晚上有空又可以碼碼技術(shù)了,今天我們就來聊一個(gè) Spring Boot3 中的新鮮玩意,聲明式 HTTP 調(diào)用。
1. 由來
Spring Boot3 去年底就已經(jīng)正式發(fā)布,我也嘗了一把鮮,最近有空會和小伙伴們慢慢聊聊 Spring Boot3 都給我們帶來了哪些新東西。
今天我們就先來看看聲明式 HTTP 接口。
用過 Spring Cloud 的小伙伴都知道,在 Spring Cloud 家族中,負(fù)責(zé)進(jìn)程間通信的,我們可以使用 RestTemplate 或者 OpenFeign(當(dāng)然也有其他方式如基于消息中間件的消息驅(qū)動(dòng)的微服務(wù)或者基于 gRPC 的調(diào)用等)。
RestTemplate 我們可以將之當(dāng)作一個(gè)普普通通的 HTTP 調(diào)用工具來對待,區(qū)別于其他的 HTTP 客戶端,RestTemplate 用來調(diào)用 RESTful 風(fēng)格的接口特別方便。
不過,比 RestTemplate 更加方便的是 OpenFeign,通過接口聲明就可以實(shí)現(xiàn)遠(yuǎn)程調(diào)用,這些的具體用法松哥在之前的視頻中講過,這里就不再贅述了。
以前我們想要用聲明式 HTTP 調(diào)用,需要通過 OpenFeign 來實(shí)現(xiàn),這個(gè)需要第三方的依賴,從 Spring6 開始(Spring Boot3),Spring 自己提供了類似的功能通過 @HttpExchange 注解也能方便的實(shí)現(xiàn) 聲明式 HTTP 調(diào)用。以后跨服務(wù)調(diào)用又多了一個(gè)選擇。
2. 使用
接下來松哥通過一個(gè)案例來和小伙伴們演示一下 @HttpExchange 注解的具體玩法。
首先我們先創(chuàng)建一個(gè)普通的名為 server 的 Spring Boot 項(xiàng)目,這個(gè)普通的 Spring Boot 項(xiàng)目中只需要提供一個(gè)簡單的測試接口即可,如下:
這個(gè)對大家來說應(yīng)該是沒什么難度的,我就不多說了。
現(xiàn)在假設(shè)我有另外一個(gè)服務(wù)名為 client,我想在 client 中調(diào)用 server 中提供的這個(gè)接口。
首先我們來創(chuàng)建 client 這個(gè)項(xiàng)目,大家注意,創(chuàng)建的時(shí)候我們不僅需要添加 Web 依賴,還需要 Reactive Web,因?yàn)檫@個(gè) @HttpExchange 底層基于 WebClient,而 WebClient 則是 Reactive Web 提供的:
創(chuàng)建完成后,接下來我們就可以聲明 Http 接口了:
這些用法跟我們在 SpringMVC 中常用的 @RequestMapping 和 @GetMapping 等特別類似:
- @HttpExchange? 類似于 @RequestMapping,可以將之放在類上,起到一個(gè)請求窄化的作用,也可以放在方法上,放在方法上我們可以通過 method 屬性來指定具體的請求方法,這個(gè)也跟 @RequestMapping 類似:@HttpExchange(value = "/server",method = "GET")。
- @GetExchange? 類似于 @GetMapping,這個(gè)就不再贅述了,其他類似的注解還有 @DeleteExchange、@PatchExchange、@PostExchange、@PutExchange 等。
- 另外需要注意的是請求方法的參數(shù)需要加上@RequestParam 注解,這一點(diǎn)和 OpenFeign 比較類似。
接口聲明好之后還沒完,我們還需要配置一下才能使用。如下:
這個(gè)配置主要是兩方面:
- @HttpExchange? 是基于 WebClient 的,所以我們首先需要配置 WebClient,配置 WebClient 的時(shí)候,也順便配置了請求的具體地址(因?yàn)樵?nbsp;@HttpExchange
- 由于我們前面提供的 ToDoService 是一個(gè)接口,所以我們還需要提供一個(gè)該接口的實(shí)現(xiàn)類,當(dāng)然這個(gè)配置完全是套路化模版化的,這塊就沒啥好說了。
全部配置完成后,接下來我們就可以在任何需要的地方,直接注入 ToDoService 的實(shí)例去使用了,舉一個(gè)簡單的例子小伙伴們參考下:
好啦,一個(gè)簡單的例子,小伙伴們不妨體驗(yàn)下。
以后,不用 OpenFeign 也能實(shí)現(xiàn)聲明式服務(wù)調(diào)用啦~