SpringBoot?調用外部接口的三種實現(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ù) httpGet.setConfig(RequestConfig.custom().setConnectTimeout(CONNECT_TIMEOUT).setSocketTimeout(SOCKET_TIMEOUT).build()); //設置請求頭 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、結果驗證
二、第二種方式(RestTemplate)
RestTemplate可用于微服務間的通信,也可以用于網絡請求。
其有多種提交方式,postForEntity、postForObject、postForLocation等等。
這是使用getForEntity進行演示。
RestTemplate 的使用很靈活需要自己根據(jù)實際使用
1、調用方法
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是用于微服務間消費使用的,也可以用于網絡請求。
這里的url應該是要放在配置文件中的,為了方便這邊就直接寫死。注意FeignClient中的name要配置 不然在測試類中會報錯
1、調用接口
/** * @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); }
到此這篇關于SpringBoot 調用外部接口的三種實現(xiàn)方法的文章就介紹到這了,更多相關SpringBoot 調用外部接口內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
java解析xml的4種方式的優(yōu)缺點對比及實現(xiàn)詳解
這篇文章主要介紹了java解析xml的4種方式的優(yōu)缺點對比及實現(xiàn)詳解,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下2019-07-07Java中線程組ThreadGroup與線程池的區(qū)別及示例
這篇文章主要介紹了Java中線程組與線程池的區(qū)別及示例,ThreadGroup是用來管理一組線程的,可以控制線程的執(zhí)行,查看線程的執(zhí)行狀態(tài)等操作,方便對于一組線程的統(tǒng)一管理,需要的朋友可以參考下2023-05-05spring?boot集成WebSocket日志實時輸出到web頁面
這篇文章主要為大家介紹了spring?boot集成WebSocket日志實時輸出到web頁面展示的詳細操作,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步2022-03-03