SpringBoot調(diào)用第三方接口的幾種方式小結
一、前言
在項目中調(diào)用第三方接口時,確實需要根據(jù)項目的技術棧、架構規(guī)范以及具體的業(yè)務需求來選擇最適合的調(diào)用方式。比如:RESTful API調(diào)用、Feign聲明式HTTP客戶端、Apache HttpClient等調(diào)用方式,每種方式都有其適用場景和優(yōu)勢。下面我們就介紹幾種調(diào)用第三方接口的實現(xiàn)方式以及代碼示例。
二、常見的調(diào)用方式
1. RESTful API調(diào)用
適用場景:當?shù)谌浇涌谧裱璕ESTful設計風格時,通常使用HTTP客戶端庫(如OkHttp、Apache HttpClient等)來發(fā)送HTTP請求并接收響應。
優(yōu)勢:
- 通用性強:RESTful API基于HTTP協(xié)議,可以跨平臺、跨語言調(diào)用。
- 靈活性高:支持各種HTTP方法(GET、POST、PUT、DELETE等),可以滿足不同的業(yè)務需求。
- 易于測試:可以使用Postman、curl等工具進行接口測試。
- 實現(xiàn)方式:使用HTTP客戶端庫構建請求,發(fā)送請求并處理響應。
2. Feign聲明式HTTP客戶端
適用場景:在Spring Cloud等微服務架構中,F(xiàn)eign可以作為聲明式HTTP客戶端,簡化HTTP請求的編寫。
優(yōu)勢:
- 簡化代碼:通過注解的方式定義HTTP請求,減少模板代碼。
- 支持負載均衡:可以配合Ribbon等組件實現(xiàn)客戶端負載均衡。
- 易于集成:與Spring Cloud等框架集成良好,方便使用。
- 實現(xiàn)方式:在Spring Boot項目中添加Feign依賴,使用注解定義HTTP請求,并通過注入的方式調(diào)用Feign客戶端。
3. Apache HttpClient
適用場景:對于需要更精細控制HTTP請求和響應的場景,可以使用Apache HttpClient。
優(yōu)勢:
功能豐富:支持HTTP/1.1和HTTP/2,提供豐富的API來構建和發(fā)送HTTP請求。
靈活性強:可以自定義請求頭、請求體、連接池等參數(shù)。
可擴展性好:支持插件式擴展,可以根據(jù)需要添加自定義功能。
實現(xiàn)方式:使用HttpClientBuilder構建HttpClient實例,通過HttpClient實例發(fā)送HTTP請求并處理響應。
4. 其他方式
- Spring的RestTemplate:在Spring框架中,RestTemplate提供了簡化的方式來調(diào)用RESTful服務。它內(nèi)部封裝了HttpClient,提供了更加簡潔的API。
- WebClient:在Spring WebFlux中,WebClient是一個響應式、非阻塞的HTTP客戶端,用于調(diào)用RESTful服務。
- GraphQL客戶端:如果第三方接口支持GraphQL,可以使用GraphQL客戶端庫(如Apollo、Relay等)來調(diào)用。
三、SpringBoot 第三方接口調(diào)用示例
1. JDK HttpClient
自Java 11起,JDK自帶了一個全新的HTTP客戶端API,用于發(fā)送HTTP請求和接收HTTP響應。
它提供了同步和異步的API,支持HTTP/1.1和HTTP/2,并且是基于CompletableFuture實現(xiàn)的異步操作。
import java.net.URI; import java.net.http.HttpClient; import java.net.http.HttpRequest; import java.net.http.HttpResponse; import java.net.http.HttpTimeoutException; public class JdkHttpClientTest { public static void main(String[] args) { HttpClient client = HttpClient.newHttpClient(); HttpRequest request = HttpRequest.newBuilder() .uri(URI.create("https://123.com")) .build(); try { HttpResponse<String> response = client.send(request, HttpResponse.BodyHandlers.ofString()); System.out.println(response.statusCode()); System.out.println(response.body()); } catch (Exception e) { e.printStackTrace(); } } }
2. Apache HttpClient
Apache HttpClient是一個功能豐富的HTTP客戶端庫,由Apache Software Foundation開發(fā),廣泛應用于各種Java項目中,用于發(fā)送HTTP請求和接收HTTP響應。
public class ApacheHttpClientTest { public static void main(String[] args) { HttpGet request = new HttpGet("https://1234.com"); CloseableHttpClient client = HttpClients.custom().build(); try { HttpClientResponseHandler<String> responseHandler = new BasicHttpClientResponseHandler(); String ret = client.execute(httpget, responseHandler) ; System.out.println(ret) ; } catch (Exception e) { e.printStackTrace(); } } }
3. OkHttp
OkHttp是一款由Square公司貢獻的開源網(wǎng)絡請求的輕量級框架,主要用于Android和Java應用。它作為現(xiàn)代HTTP客戶端,具備高效、易用、功能強大的特點。
public void OkHttpClientTest() { // 1. 創(chuàng)建一個OkHttpClient實例 OkHttpClient client = new OkHttpClient(); // 2. 創(chuàng)建一個Request對象 Request request = new Request.Builder().url("http://1234.com") // 設置請求的URL .build(); // 3. 發(fā)送請求并獲取Response對象 try (Response response = client.newCall(request).execute()) { String responseBody = response.body().string(); System.out.println(responseBody); } catch (IOException e) { e.printStackTrace(); } }
4. RestTemplate
RestTemplate是Spring框架中的一個類,它提供了一個高層次的RESTful web service客戶端。
它簡化了與RESTful web services的集成,并提供了多種方法來發(fā)送HTTP請求和接收HTTP響應。
public class RestTemplateTest { public static void main(String[] args) { RestTemplate restTemplate = new RestTemplate(); String response = restTemplate.getForObject("https://1234.com", String.class); System.out.println(response); } }
5. WebClient
WebClient 是Spring WebFlux提供的一個非阻塞的、響應式的Web客戶端,用于發(fā)起HTTP請求。它特別適用于響應式編程模型和Spring WebFlux應用程序。
public class WebClientExample { public static void main(String[] args) { WebClient webClient = WebClient.create("http://1234.com"); webClient.get() .uri("/api/data") .retrieve() .bodyToMono(String.class) .subscribe( body -> System.out.println(body), error -> System.err.println("Error occurred: " + error) ); } }
6. OpenFeign
注意這里是OpenFeign可不是Spring Cloud OpenFeign,Spring Cloud openfeign對OpenFeign進行了包裝,所以在使用上是有差別的。
添加依賴
<dependency> <groupId>io.github.openfeign</groupId> <artifactId>feign-core</artifactId> <version>13.2.1</version> </dependency>
public interface MyFeignClient { @RequestLine("GET /api/data") String getData(); static MyFeignClient create() { return Feign.builder() .encoder(new JacksonEncoder()) .decoder(new JacksonDecoder()) .logger(new Logger.ErrorLogger()) .logLevel(Level.FULL) .retryer(new Retryer.Default(100, TimeUnit.MILLISECONDS.toMillis(1), 5)) .target(Target.EmptyTarget.create(MyFeignClient.class, "http://123456.com")); } }
MyFeignClient client = MyFeignClient.create(); String data = client.getData(); System.out.println(data);
以上對 Spring Boot 調(diào)用外部接口的六種方式進行了簡單介紹,但實踐中需要依據(jù)項目具體需求和實際情況進行選擇,以確保項目導向和效率最優(yōu)。
到此這篇關于SpringBoot調(diào)用第三方接口的幾種方式小結的文章就介紹到這了,更多相關SpringBoot調(diào)用第三方接口內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
maven package 打包報錯 Failed to execute goal的解決
這篇文章主要介紹了maven package 打包報錯 Failed to execute goal的解決,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2020-11-11Java與Oracle實現(xiàn)事務(JDBC事務)實例詳解
這篇文章主要介紹了Java與Oracle實現(xiàn)事務(JDBC事務)實例詳解的相關資料,需要的朋友可以參考下2017-05-05Spring 定時任務@Scheduled 注解中的 Cron 表達式詳解
Cron 表達式是一種用于定義定時任務觸發(fā)時間的字符串表示形式,它由七個字段組成,分別表示秒、分鐘、小時、日期、月份、星期和年份,這篇文章主要介紹了Spring 定時任務@Scheduled 注解中的 Cron 表達式,需要的朋友可以參考下2023-07-07