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

Spring最新HTTP接口調用工具RestClient

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

環境:SpringBoot3.2.1

1. 簡介

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

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

2. 創建RestClient實例

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

一旦創建(或構建),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發出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設置請求體,這樣就可以使用泛型。最后,函數體可以設置為一個回調函數,用于寫入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響應??梢允褂胋ody(Class)或body(ParameterizedTypeReference)來訪問響應主體,參數化類型如列表。body方法將響應內容轉換為各種類型,例如bytes可以轉換為字符串,JSON可以使用Jackson轉換為對象等。

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

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

通過ResponseEntity可以訪問響應的狀態碼和響應頭:

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 錯誤處理

默認情況下,當返回的狀態碼為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時不會應用狀態處理程序,因為exchange方法已經提供了對完整響應的訪問,允許執行任何必要的錯誤處理。

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庫來執行HTTP請求。這些庫通過ClientRequestFactory接口進行調整。有各種可用的實現:

  • 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全家桶實戰案例源碼
相關推薦

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

模型數據

2011-02-21 12:44:05

Postfix

2022-02-25 09:03:49

工具Swift項目

2010-06-12 13:59:12

2023-11-29 07:34:05

Spring工具類項目

2024-10-18 08:00:00

SpringBoot框架開發

2025-02-22 08:00:00

AgentSpringBootJava

2025-04-02 04:55:00

2011-04-08 17:24:05

c++工具編程

2019-02-13 14:58:43

cssjavascript前端

2019-07-08 15:10:17

JS工具函數

2011-01-14 13:40:24

UbuntuLinux Tips

2022-09-26 10:01:04

SpringAOP日志

2024-09-30 10:11:04

點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 亚洲国产精久久久久久久 | 久久久久国产精品午夜一区 | 自拍偷拍小视频 | 亚洲国产精品一区二区久久 | 久久蜜桃av一区二区天堂 | 日韩视频精品在线 | www.99热.com| 日韩中文在线视频 | 精品国产一区二区三区久久久四川 | 中文字幕精品视频在线观看 | 国产精品久久久爽爽爽麻豆色哟哟 | 国产成人精品免费视频 | 精产国产伦理一二三区 | 亚洲毛片在线 | 精品一区二区在线观看 | 日韩黄| 久久成人精品视频 | 99久久国产免费 | 亚洲免费在线 | 日韩一区二区免费视频 | 免费精品久久久久久中文字幕 | 一级黄色短片 | 狠狠色综合久久丁香婷婷 | 91在线免费视频 | 成人免费在线播放 | h视频在线免费观看 | 韩国精品在线 | 国产精品777一区二区 | 国产激情免费视频 | 中文字幕日韩欧美一区二区三区 | 亚洲综合五月天婷婷 | 免费的色网站 | 爱爱免费视频网站 | 天天干天天干 | 欧美男人亚洲天堂 | 黄毛片| 国产大学生情侣呻吟视频 | 日韩在线电影 | zzzwww在线看片免费 | 国产亚洲精品久久久优势 | 国产一区二区三区久久久久久久久 |