SpringBoot?調(diào)用外部接口的三種實現(xiàn)方法
一、第一種方式(HttpClient等)
使用插件方式,比如自帶的HttpClient,或者OkHttp,甚至是原生的HttpURLConnection 等等,這里以HttpClient為例。
1、封裝工具類
簡單封裝的get請求
/**
* 發(fā)送get請求:帶請求頭和請求參數(shù)
*
* @param url 請求地址
* @param headers 請求頭
* @param params 請求參數(shù)集合
* @return JSONObject
* @throws Exception
*/
public static JSONObject doGet(String url, Map<String, Object> headers, Map<String, Object> params) throws Exception {
//創(chuàng)建httpClient對象
CloseableHttpClient httpClient = HttpClients.createDefault();
URIBuilder uriBuilder = new URIBuilder(url);
if (params != null) {
Set<Map.Entry<String, Object>> entrySet = params.entrySet();
for (Map.Entry<String, Object> entry : entrySet) {
uriBuilder.setParameter(entry.getKey(), String.valueOf(entry.getValue()));
}
}
URI uri = uriBuilder.build();
HttpGet httpGet = new HttpGet(uri);
//設(shè)置參數(shù)
httpGet.setConfig(RequestConfig.custom().setConnectTimeout(CONNECT_TIMEOUT).setSocketTimeout(SOCKET_TIMEOUT).build());
//設(shè)置請求頭
packageHeader(headers, httpGet);
CloseableHttpResponse httpResponse = null;
try {
return getResponse(httpResponse, httpClient, httpGet);
} finally {
release(httpResponse, httpClient);
}
}2、測試
Map<String,Object> headers=new HashMap<>();
headers.put("Key","換成你自己的key");
Map<String,Object> query=new HashMap<>();
query.put("city","350200");
JSONObject jsonObject = HttpUtil.doGet("https://restapi.amap.com/v3/weather/weatherInfo", headers, query);
log.info(JSONUtil.toJsonStr(jsonObject));3、結(jié)果驗證

二、第二種方式(RestTemplate)
RestTemplate可用于微服務(wù)間的通信,也可以用于網(wǎng)絡(luò)請求。
其有多種提交方式,postForEntity、postForObject、postForLocation等等。
這是使用getForEntity進行演示。
RestTemplate 的使用很靈活需要自己根據(jù)實際使用
1、調(diào)用方法
RestTemplate restTemplate = new RestTemplate();
//創(chuàng)建請求頭
HttpHeaders httpHeaders = new HttpHeaders();
//參數(shù)
Map<String, Object> query = new HashMap<>();
query.put("city", "350200");
query.put("Key", "換成你自己的key");
HttpEntity<Map<String, Object>> httpEntity = new HttpEntity<>(httpHeaders);
String url = "https://restapi.amap.com/v3/weather/weatherInfo?city={city}&Key={Key}";
//請求地址、請求體以及返回參數(shù)類型
ResponseEntity<JSONObject> responseEntity = restTemplate.getForEntity(url, JSONObject.class, query);
log.info(JSONUtil.toJsonStr(responseEntity));
三、第三種方式(Feign)
引入依賴
<!-- spring-cloud-starter-openfeign -->
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-openfeign</artifactId>
<version>4.0.0</version>
</dependency>feign是用于微服務(wù)間消費使用的,也可以用于網(wǎng)絡(luò)請求。
這里的url應(yīng)該是要放在配置文件中的,為了方便這邊就直接寫死。注意FeignClient中的name要配置 不然在測試類中會報錯
1、調(diào)用接口
/**
* @author xysusj
*/
@FeignClient(url = "https://restapi.amap.com/v3/weather/weatherInfo",name = "weatherApi")
public interface WeatherApi {
/**
* 獲取天氣詳情
*
* @param key
* @param city
* @return
*/
@GetMapping(value = "")
JSONObject getWeather(@RequestParam("Key") String key, @RequestParam("city") String city);
}
到此這篇關(guān)于SpringBoot 調(diào)用外部接口的三種實現(xiàn)方法的文章就介紹到這了,更多相關(guān)SpringBoot 調(diào)用外部接口內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
java解析xml的4種方式的優(yōu)缺點對比及實現(xiàn)詳解
這篇文章主要介紹了java解析xml的4種方式的優(yōu)缺點對比及實現(xiàn)詳解,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下2019-07-07
解決Swagger2返回map復(fù)雜結(jié)構(gòu)不能解析的問題
這篇文章主要介紹了解決Swagger2返回map復(fù)雜結(jié)構(gòu)不能解析的問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2021-07-07
Java隊列數(shù)據(jù)結(jié)構(gòu)的實現(xiàn)
這篇文章主要介紹了Java隊列數(shù)據(jù)結(jié)構(gòu)的實現(xiàn),隊列是一種特殊的線性表,只允許在表的隊頭進行刪除操作,在表的后端進行插入操作,隊列是一個有序表先進先出,想了解更多相關(guān)資料的小伙伴可以參考下面文章的詳細內(nèi)容2021-12-12
Java中線程組ThreadGroup與線程池的區(qū)別及示例
這篇文章主要介紹了Java中線程組與線程池的區(qū)別及示例,ThreadGroup是用來管理一組線程的,可以控制線程的執(zhí)行,查看線程的執(zhí)行狀態(tài)等操作,方便對于一組線程的統(tǒng)一管理,需要的朋友可以參考下2023-05-05
spring?boot集成WebSocket日志實時輸出到web頁面
這篇文章主要為大家介紹了spring?boot集成WebSocket日志實時輸出到web頁面展示的詳細操作,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步2022-03-03

