成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

Spring最新HTTP接口調用工具RestClient

開發(fā) 前端
如果在構建RestClient時沒有指定請求工廠,它將使用classpath中提供的Apache或Jetty HttpClient。否則,如果加載了java.net.http模塊,它將使用Java的HttpClient。

環(huán)境:SpringBoot3.2.1

1. 簡介

客戶端執(zhí)行HTTP請求,在底層的HTTP客戶端庫(如JDK HttpClient、ApacheHttpComponents等)上公開流暢、同步的API。

RestClient是一個同步HTTP客戶端,它提供了一個現(xiàn)代、流暢的API。它提供了對HTTP庫的抽象,允許從Java對象到HTTP請求的方便轉換,以及從HTTP響應創(chuàng)建對象。

2. 創(chuàng)建RestClient實例

RestClient是使用一個靜態(tài)create方法創(chuàng)建的。還可以通過builder來獲得帶有進一步選項的builder,例如指定使用哪個HTTP庫和使用哪個消息轉換器,設置默認URI、默認路徑變量、默認請求頭或uriBuilderFactory,或注冊攔截器和初始化器。

一旦創(chuàng)建(或構建),RestClient就可以被多個線程安全地使用。

示例:

// 簡單create方式
RestClient defaultClient = RestClient.create() ;
// 通過builder構建
RestClient customClient = RestClient.builder()
  .requestFactory(new HttpComponentsClientHttpRequestFactory())
  .messageConverters(converters -> converters.add(new PackCustomMessageConverter()))
  .baseUrl("http://api.pack.com")
  .defaultUriVariables(Map.of("name", "zs"))
  .defaultHeader("My-Header", "Foo")
  .requestInterceptor(...)
  .requestInitializer(...)
  .build() ;

3. 使用RestClient

當使用RestClient發(fā)出HTTP請求時,首先要指定使用哪個HTTP方法。這可以使用method(HttpMethod),或者使用便利方法get()、head()、post()等來完成。

RestClient restClient = RestClient.create("http://api.pack.com") ;
restClient.get() ;
restClient.post() ;
// 或
restClient.method(HttpMethod.GET) ;

3.1 Request URI

接下來,可以用URI方法指定請求URI。此步驟是可選的,如果RestClient配置了默認URI,則可以跳過此步驟。URL通常指定為字符串,帶有可選的URI模板變量。默認情況下,字符串url是編碼的,但是可以通過使用自定義uriBuilderFactory構建客戶端來更改。

RestClient restClient = RestClient.create("http://api.pack.com") ;
restClient.method(HttpMethod.GET).uri("/users") ;

3.2 Request Headers And Body

如果有必要,可以通過添加請求頭header(String, String)、header(Consumer<HttpHeaders>),或者使用便利方法accept(MediaType…)、acceptCharset(Charset…)等來操作HTTP請求。對于可以包含正文(POST、PUT和PATCH)的HTTP請求,還有其他方法:contentType(MediaType)和contentLength(long)。

請求體本身可以通過body(Object)設置,它在內部使用HTTP消息轉換。或者,可以使用ParameterizedTypeReference設置請求體,這樣就可以使用泛型。最后,函數(shù)體可以設置為一個回調函數(shù),用于寫入OutputStream。

RestClient restClient = RestClient.create("http://api.pack.com") ;
restClient
  .post()
  .uri("/users")
  .body(new User(666L, "張三", 23))
  .header("X-API-VERSION", "1.0")

3.3 獲取響應結果

設置好請求后,調用retrieve()方法訪問HTTP響應。可以使用body(Class)或body(ParameterizedTypeReference)來訪問響應主體,參數(shù)化類型如列表。body方法將響應內容轉換為各種類型,例如bytes可以轉換為字符串,JSON可以使用Jackson轉換為對象等。

響應也可以被轉換為ResponseEntity,以便訪問響應頭和響應體。

RestClient restClient = RestClient.create("http://api.pack.com") ;
restClient
  .get()
  .uri("/users/666")
  .retrieve()
  .body(User.class) ;

通過ResponseEntity可以訪問響應的狀態(tài)碼和響應頭:

RestClient restClient = RestClient.create("http://api.pack.com") ;
ResponseEntity<String> result = restClient.get() 
  .uri("/users/666") 
  .accept(APPLICATION_JSON)
  .retrieve()
  .toEntity(User.class) ; 
System.out.println("Response status: " + result.getStatusCode()); 
System.out.println("Response headers: " + result.getHeaders()); 
System.out.println("Contents: " + result.getBody());

3.4 錯誤處理

默認情況下,當返回的狀態(tài)碼為4xx或5xx的響應時,RestClient會拋出RestClientException的子類。這種行為可以用onStatus來覆蓋。

String result = restClient.get() 
  .uri("/users/{id}", id) 
  .retrieve()
  // 自定義4xx錯誤
  .onStatus(HttpStatusCode::is4xxClientError, (request, response) -> { 
    throw new MyCustomRuntimeException(response.getStatusCode(), response.getHeaders()) 
  })
  .body(String.class) ;

onStatus方法

圖片圖片

3.5 Exchange

對于更高級的場景,RestClient通過exchange方法提供對底層HTTP請求和響應的訪問,可以使用該方法代替retrieve()。使用exchange時不會應用狀態(tài)處理程序,因為exchange方法已經提供了對完整響應的訪問,允許執(zhí)行任何必要的錯誤處理。

RestClient restClient = RestClient.create("http://api.pack.com") ;
restClient
  .post()
  .uri("/users/666")
  .body(new User())
  .header("X-API-VERSION", "1.0")
  .exchange((request, response) -> {
    if (response.getStatusCode().is4xxClientError()) {
      throw new RuntimeException(String.format("status: %d, headers: %s", response.getStatusCode(), response.getHeaders())) ; 
    } else {
      return response.getBody() ;
    }
  }) ;

3.6 客戶端請求工廠

RestClient使用客戶端HTTP庫來執(zhí)行HTTP請求。這些庫通過ClientRequestFactory接口進行調整。有各種可用的實現(xiàn):

  • JdkClientHttpRequestFactory for Java’s HttpClient,
  • HttpComponentsClientHttpRequestFactory for use with Apache HTTP Components HttpClient,
  • JettyClientHttpRequestFactory for Jetty’s HttpClient,
  • ReactorNettyClientRequestFactory for Reactor Netty’s HttpClient,
  • SimpleClientHttpRequestFactory as a simple default.

如果在構建RestClient時沒有指定請求工廠,它將使用classpath中提供的Apache或Jetty HttpClient。否則,如果加載了java.net.http模塊,它將使用Java的HttpClient。

以上是本篇文章的全部內容,希望對你有幫助。

責任編輯:武曉燕 來源: Spring全家桶實戰(zhàn)案例源碼
相關推薦

2023-03-16 08:14:57

2009-09-07 10:34:47

2024-03-11 09:32:55

WebClientSpringHTTP

2023-12-11 08:15:53

Spring6遠程接口

2015-03-23 12:26:49

2009-07-10 17:54:29

SwingUtilit

2024-10-24 14:30:00

模型數(shù)據(jù)

2022-02-25 09:03:49

工具Swift項目

2010-06-12 13:59:12

2011-02-21 12:44:05

Postfix

2023-11-29 07:34:05

Spring工具類項目

2025-02-22 08:00:00

AgentSpringBootJava

2024-10-18 08:00:00

SpringBoot框架開發(fā)

2025-04-02 04:55:00

2022-09-26 10:01:04

SpringAOP日志

2011-01-14 13:40:24

UbuntuLinux Tips

2011-04-08 17:24:05

c++工具編程

2019-02-13 14:58:43

cssjavascript前端

2019-07-08 15:10:17

JS工具函數(shù)

2024-09-30 10:11:04

點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 一区二区三区欧美 | 精品国产91乱码一区二区三区 | 欧美在线视频一区二区 | 亚洲天堂精品一区 | 欧美男人天堂 | 搞av.com| 日韩在线观看视频一区 | 国产欧美日韩视频 | 午夜小视频在线播放 | 美女黄网| 日本一区二区三区在线观看 | 99精品国产一区二区三区 | 免费久久久 | 国产精品久久久久久吹潮日韩动画 | 国产成人精品999在线观看 | 国产成人精品一区二区三区网站观看 | 久久九九99| 国产视频久久久 | 成人午夜精品 | 亚洲免费网址 | 爱爱小视频 | 久久亚洲国产精品 | 日韩一区二区三区视频 | av片毛片| 第一区在线观看免费国语入口 | 欧美国产91| 亚洲性人人天天夜夜摸 | 超碰成人在线观看 | 狠狠操狠狠干 | 久久精品国产清自在天天线 | 五月婷婷亚洲 | 精品日韩一区二区 | 成人在线视频观看 | 蜜桃毛片| 国产欧美日韩视频 | 国产精品久久久久久久久久免费看 | 色欧美综合 | 亚洲视频自拍 | 欧美天堂在线 | 欧美性生活一区二区三区 | 久草视频在 |