您好,登錄后才能下訂單哦!
本篇內容主要講解“Java怎么調用接口獲取json數據解析后保存到數據庫”,感興趣的朋友不妨來看看。本文介紹的方法操作簡單快捷,實用性強。下面就讓小編來帶大家學習“Java怎么調用接口獲取json數據解析后保存到數據庫”吧!
1.在yml文件中配置自己定義的接口URL
//自己定義的JSON接口URL blacklist_data_url: 接口URL
2.在Controller中添加請求方法和路徑
/** * @Title: 查詢 * @Description: 查詢車輛的記錄 * @Author: 半度納 * @Date: 2022/9/27 17:33 */ @GetMapping("/Blacklist") public void selectBlacklist(){ boolean a = imBuBlacklistService.selectBlacklist();//調用業務層方法 }
3.在Service中添加方法
/** * @Title: 查詢 * @Description: 查詢車輛的記錄 * @Author: 半度納 * @Date: 2022/9/27 17:33 * @return */ public boolean selectBlacklist();//返回值類型沒要求
4.在ServiceImpl中實現方法
import cn.hutool.json.JSONArray; import cn.hutool.json.JSONObject; import com.alibaba.fastjson2.JSON; @Value("${blacklist_data_url}") public String blacklist_data_url;//接口URL /** * @Title: 查詢 * @Description: 查詢車輛的記錄 * @Author: 半度納 * @Date: 2022/9/27 17:33 * @return */ @Override public boolean selectBlacklist() { //獲取的JSON接口數據(在輸出測試時sendGet方法可能會自動輸出,具體需看底層代碼) String list= HttpUtils.sendGet(blacklist_data_url); JSONObject j = JSON.parseObject(list);//將獲取的JSON數據存儲到變量中 if(j.getBoolean("success")){//獲取success判斷是否為空 JSONObject jsonData = j.getJSONObject("body");//解析JSON的body JSONArray jsonArray = jsonData.getJSONArray("data");//解析JSON的data數據 JSONObject row = null;//定義一個空變量 ImBuBlacklist buBlacklist=new ImBuBlacklist();//new一個實體類用來接收數據 for (int y = 0; y < jsonArray.size(); ++y) {//循環將JSON數據存儲到數據庫中 buBlacklist = new ImBuBlacklist();//new一個實體類存儲數據 row = jsonArray.getJSONObject(y);//獲取數組中的數據 //設置獲取到的JSON號牌號碼到實體類的相同字段中 buBlacklist.setPlateNumber(row.getString("mechanicalNumber")); //設置獲取到的JSON車輛類型到實體類的相同字段中 buBlacklist.setVehicleType(row.getString("machType")); //設置獲取到的JSON檢查日期到實體類的相同字段中 buBlacklist.setExamineDate(row.getDate("createDate")); //設置獲取到的JSON檢查地點到實體類的相同字段中 buBlacklist.setExamineAddress(row.getString("machineAddr")); //設置獲取到的JSON違規行為到實體類的相同字段中 buBlacklist.setIllegalBehavior(row.getString("joinTheBlacklistReason")); //設置獲取到的JSON黑名單類型到實體類的相同字段中 buBlacklist.setBlacklistType(row.getInteger("violations")); //通過mapper的新增方法,把實體類中的JSON數據存到數據庫中 imBuBlacklistMapper.insertImBuBlacklist(buBlacklist); } return true;//自己定義的返回值(沒有用) }else{ return false; } }
通過get(httpGet)請求獲取接口數據,使用HttpClient基本分六步:
創建HttpClient實例
創建某種連接方法的實例
調用HttpClient實例的execute方法來執行請求方法
讀取response
釋放連接,無論執行方法是否成功
//創建httpClient實例 CloseableHttpClient client = HttpClients.createDefault(); //汽車之家api接口 String apiPath = "https://www.autohome.com.cn/ashx/index/GetHomeFindCar.ashx"; //創建get方法請求實例 HttpGet httpGet = new HttpGet(apiPath); //添加表頭,text/xml表示XML格式 httpGet.addHeader("content-type","text/xml"); //調用HttpClient實例執行GET實例,返回response HttpResponse response = client.execute(httpGet); //解析response,這個過程主要取決于獲取的json格式,是一個對象還是一個數組,放到后面詳解 String result = EntityUtils.toString(response.getEntity()); //釋放連接 response.close(); client.close();
其中我們可以對response的狀態(state)進行判斷,驗證是否獲取數據. 頁面請求的狀態值,分別有:200請求成功、303重定向、400請求錯誤、401未授權、403禁止訪問、404文件未找到、500服務器錯誤.
(HttpStatus.OK = 200;HttpStatus.BAD_REQUEST = 400;HttpStatus.FORBIDDEN = 403;HttpStatus.NOT_FOUND = 404;HttpStatus.SERVICE_UNAVAILABLE =500)
if (response.getStatusLine().getStatusCode() == HttpStatus.SC_OK) { String result = EntityUtils.toString(response.getEntity());//解析response }//getStatusLine()方法返回保存請求狀態的StatusLine對象,getStatusCode()獲取狀態碼
在解析json字符串之前,我們一定要先確定json字符串的格式,針對不同的格式要使用不同的解析方法這里列舉了一些常見的json字符串格式
例如:數值,字符串,數組,對象數組或數組對象.重點就在于花括號和中括號的使用,一定要注意這兩個符號,可能會導致json解析錯誤.
//json數值 { "key" : 520, "key1" : 1314 } //json字符串 { "key" : "我愛你", "key1" : "一生一世" } //json數組 { "key" : [520, 1314], "key1" : [520, 3344] } //json對象數組 { "我" : [ {"key": "我愛你"}, {"key1": "一生一世"} ] } //json數組對象 { "我" : { [520,1314], ["我愛你", "一生一世"] } }
可以看出從汽車之家獲取的json字符串是json數組格式的,所以我們要用JSONArray進行解析,然后再對json數組進行遍歷,獲取每一個json對象,然后對json對象進行數據的讀取.
//將json字符串解析成json數組的形式 JSONArray jsonArray = JSONArray.parseArray(result); //利用遍歷解析json數組,并在循環中解析每一個json對象 for (int i = 0; i < jsonArray.size(); i++) { //將json數組解析為每一個jsonObject對象 JSONObject object=jsonArray.getJSONObject(i); //實例化一個dao層或者domain層的對象 CarBrand Brand = new CarBrand(); //將json對象中的數據寫入實例化的對象中 //注意object讀取的字段要和json對象中的字段一樣,否則無法解析 Brand.setId(object.getInteger("id")); Brand.setName(object.getString("name")); Brand.setGroup(object.getString("letter")); }
在springboot框架之中,mybatis-generator可以生成domain層的實體文件,xml文件,mapper文件和相應的service文件,利用這個插件可以省去我們寫sql語句的時間,我們可以在service層直接調用相應的方法.
//調用service層的add方法,直接將實例化對象寫入數據庫 CarBrandService.add(Brand);
完整代碼如下
package org.linlinjava.litemall.admin.service; import com.alibaba.fastjson.JSONArray; import com.alibaba.fastjson.JSONObject; import org.apache.http.HttpResponse; import org.apache.http.HttpStatus; import org.apache.http.client.methods.HttpGet; import org.apache.http.impl.client.CloseableHttpClient; import org.apache.http.impl.client.HttpClients; import org.apache.http.util.EntityUtils; import org.linlinjava.litemall.db.dao.LitemallCarBrandMapper; import org.linlinjava.litemall.db.domain.LitemallCarBrand; import org.linlinjava.litemall.db.service.LitemallCarBrandService; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.stereotype.Service; import java.time.LocalDateTime; import java.util.List; import java.util.Map; @Service public class AdminCarBrandService { @Autowired CarBrandService carBrandService; public void httpRequest() { //使用httpclient獲取api數據 CloseableHttpClient client = HttpClients.createDefault(); String apiPath = "https://www.autohome.com.cn/ashx/index/GetHomeFindCar.ashx"; HttpGet httpGet = new HttpGet(apiPath); try{ httpGet.addHeader("content-type","text/xml"); HttpResponse response = client.execute(httpGet); if (response.getStatusLine().getStatusCode() == HttpStatus.SC_OK) { //對獲取的string數據進行json解析 String result = EntityUtils.toString(response.getEntity()); JSONArray jsonArray = JSONArray.parseArray(result); for (int i = 0; i < jsonArray.size(); i++) { //將json對象中的數據寫入實例化對象中 CarBrand carBrand = new CarBrand(); JSONObject object=jsonArray.getJSONObject(i); carBrand.setId(object.getInteger("id")); carBrand.setName(object.getString("name")); carBrand.setGroup(object.getString("letter")); //將實例化對象存入數據庫 carBrandService.add(CarBrand); } } }catch (Exception e){ throw new RuntimeException(e); } } }
到此,相信大家對“Java怎么調用接口獲取json數據解析后保存到數據庫”有了更深的了解,不妨來實際操作一番吧!這里是億速云網站,更多相關內容可以進入相關頻道進行查詢,關注我們,繼續學習!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。