在最近發佈的Spring 6.1 M2版本中,推出了一個全新的同步HTTP客戶端:`RestClient`。用一句話來讓Spring開發者認識`RestClient`的話:像`WebClient`一樣具備流暢API的`RestTemplate`。所以,`RestClient`的使命就是淘汰已經有14 ...
在最近發佈的Spring 6.1 M2版本中,推出了一個全新的同步HTTP客戶端:RestClient
。用一句話來讓Spring開發者認識RestClient
的話:像WebClient
一樣具備流暢API的RestTemplate
。所以,RestClient
的使命就是淘汰已經有14年曆史的RestTemplate
。
關於WebClient
和RestTemplate
,之前在幾種服務消費方式(RestTemplate、WebClient、Feign)這篇文章中有詳細的介紹。如果您有一定的瞭解,那麼對於RestClient
一定可以快速上手。
RestClient
案例
下麵我們通過幾個官方給出的案例一起來快速的認識一下RestClient
。
HTTP請求
下麵是一個最簡單的GET請求,返回一個字元串。從這個例子中,我們可以看到API形式跟WebClient
類似。不像以前用RestTemplate
的時候那麼麻煩。
RestClient restClient = RestClient.create();
String result = restClient.get()
.uri("https://example.com")
.retrieve()
.body(String.class);
System.out.println(result);
關於GET請求,很多時候我們返回的不僅僅是String,更多的時候是一些實體;同時我們有時候還需要獲取HTTP狀態碼以及頭信息。這個時候,我們可以使用toEntity
方法來返回一個更為通用的ResponseEntity
來進行後續操作,比如下麵這樣:
ResponseEntity<String> result = restClient.get()
.uri("https://example.com")
.retrieve()
.toEntity(String.class);
System.out.println("Response status: " + result.getStatusCode());
System.out.println("Response headers: " + result.getHeaders());
System.out.println("Contents: " + result.getBody());
在業務層面,為了更方便的解析業務數據。RestClient
還支持對結果進行對象轉換。比如下麵的例子,就是把HTTP請求返回的JSON數據轉化為Pet
對象。這樣就免去了開發者手動從ResponseEntity中獲取內容,再進行消息轉化的麻煩。
int id = ...
Pet pet = restClient.get()
.uri("https://petclinic.example.com/pets/{id}", id)
.accept(APPLICATION_JSON)
.retrieve()
.body(Pet.class);
關於其他請求,也是類似的,比如下麵的POST請求:
Pet pet = ...
ResponseEntity<Void> response = restClient.post()
.uri("https://petclinic.example.com/pets/new")
.contentType(APPLICATION_JSON)
.body(pet)
.retrieve()
.toBodilessEntity();
錯誤處理
預設情況下,RestClient
在接收到4xx和5xx狀態碼的時候,會拋出一個RestClientException
的子類。對於這個動作,我們可以通過onStatus
方法去重寫它,比如下麵這樣:
String result = restClient.get()
.uri("https://example.com/this-url-does-not-exist")
.retrieve()
.onStatus(HttpStatusCode::is4xxClientError, (request, response) -> {
throw new MyCustomRuntimeException(response.getStatusCode(), response.getHeaders())
})
.body(String.class);
上面的例子是進一步做了包裝,並重新拋出。當然您也可以做一些業務性的其他操作。
高級處理 Exchange
直接看下麵的例子:
Pet result = restClient.get()
.uri("https://petclinic.example.com/pets/{id}", id)
.accept(APPLICATION_JSON)
.exchange((request, response) -> {
if (response.getStatusCode().is4xxClientError()) {
throw new MyCustomRuntimeException(response.getStatusCode(), response.getHeaders());
}
else {
Pet pet = convertResponse(response);
return pet;
}
});
exchange方法提供了更靈活且完整的請求處理入口。在這裡,開發者里獲取到request
信息,也可以操作response
信息。所以,如果您有複雜的處理邏輯上一節中的請求方法無法滿足你需要的時候,就可以通過這裡的exchange
方法來定製複雜的處理邏輯。
小結
相信大家對RestTemplate
一定都不陌生,但實際應用估計已經不是很多了,更多的會使用一些其他的客戶端來實現HTTP的調用。如今Spring 6.1將推出的RestClient
將很好的彌補這塊不足,同時與WebClient
互相補充。好了,今天的學習就到這裡!如果您學習過程中如遇困難?可以加入我們超高質量的Spring技術交流群,參與交流與討論,更好的學習與進步!更多Spring Boot教程可以點擊直達!,歡迎收藏與轉發支持!
歡迎關註我的公眾號:程式猿DD。第一時間瞭解前沿行業消息、分享深度技術乾貨、獲取優質學習資源