Java調(diào)用接口如何獲取json數(shù)據(jù)解析后保存到數(shù)據(jù)庫
Java調(diào)用接口獲取json數(shù)據(jù)保存到數(shù)據(jù)庫
今天給大家?guī)硪粋€調(diào)用接口,來獲取數(shù)據(jù)解析后再保存到數(shù)據(jù)庫中的業(yè)務(wù),業(yè)務(wù)中的Mapper和實(shí)體類我就不在這里寫了,相信大家都會寫新增的SQL和定義實(shí)體類。
下面是我寫的業(yè)務(wù)代碼,有什么建議可以給我評論留言。
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();//調(diào)用業(yè)務(wù)層方法
? ? }3.在Service中添加方法
?? ?/** ? ? ?* @Title: 查詢 ? ? ?* @Description: 查詢車輛的記錄 ? ? ?* @Author: 半度納 ? ? ?* @Date: 2022/9/27 17:33 ? ? ?* @return ? ? ?*/ ? ? public boolean selectBlacklist();//返回值類型沒要求
4.在ServiceImpl中實(shí)現(xiàn)方法
?? ?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接口數(shù)據(jù)(在輸出測試時sendGet方法可能會自動輸出,具體需看底層代碼)
? ? ? ? String list= HttpUtils.sendGet(blacklist_data_url);
? ? ? ? JSONObject j = JSON.parseObject(list);//將獲取的JSON數(shù)據(jù)存儲到變量中
? ? ? ? if(j.getBoolean("success")){//獲取success判斷是否為空
? ? ? ? ? ? JSONObject jsonData = j.getJSONObject("body");//解析JSON的body
? ? ? ? ?? ?JSONArray jsonArray = jsonData.getJSONArray("data");//解析JSON的data數(shù)據(jù)
? ? ? ? ?? ?JSONObject row = null;//定義一個空變量
? ? ? ? ?? ?ImBuBlacklist buBlacklist=new ImBuBlacklist();//new一個實(shí)體類用來接收數(shù)據(jù)
? ? ? ? ?? ?for (int y = 0; y < jsonArray.size(); ++y) {//循環(huán)將JSON數(shù)據(jù)存儲到數(shù)據(jù)庫中
? ? ? ? ? ? ?? ?buBlacklist = new ImBuBlacklist();//new一個實(shí)體類存儲數(shù)據(jù)
? ? ? ? ? ? ?? ?row = jsonArray.getJSONObject(y);//獲取數(shù)組中的數(shù)據(jù)
? ? ? ? ? ??? ??? ?//設(shè)置獲取到的JSON號牌號碼到實(shí)體類的相同字段中
? ? ? ? ? ? ?? ?buBlacklist.setPlateNumber(row.getString("mechanicalNumber"));
? ? ? ? ? ? ?? ?//設(shè)置獲取到的JSON車輛類型到實(shí)體類的相同字段中
? ? ? ? ? ? ?? ?buBlacklist.setVehicleType(row.getString("machType"));
? ? ? ? ? ? ?? ?//設(shè)置獲取到的JSON檢查日期到實(shí)體類的相同字段中
? ? ? ? ? ??? ??? ?buBlacklist.setExamineDate(row.getDate("createDate"));
? ? ? ? ? ? ?? ?//設(shè)置獲取到的JSON檢查地點(diǎn)到實(shí)體類的相同字段中
? ? ? ? ? ? ?? ?buBlacklist.setExamineAddress(row.getString("machineAddr"));
? ? ? ? ? ? ?? ?//設(shè)置獲取到的JSON違規(guī)行為到實(shí)體類的相同字段中
? ? ? ? ? ? ?? ?buBlacklist.setIllegalBehavior(row.getString("joinTheBlacklistReason"));
? ? ? ? ? ? ?? ?//設(shè)置獲取到的JSON黑名單類型到實(shí)體類的相同字段中
? ? ? ? ? ? ?? ?buBlacklist.setBlacklistType(row.getInteger("violations"));
? ? ? ? ? ? ?? ?//通過mapper的新增方法,把實(shí)體類中的JSON數(shù)據(jù)存到數(shù)據(jù)庫中
? ? ? ? ? ? ?? ?imBuBlacklistMapper.insertImBuBlacklist(buBlacklist);
? ? ? ? ?? ?}
? ? ? ? ?? ?return true;//自己定義的返回值(沒有用)
? ? ? ? }else{
? ? ? ? ? ? return false;
? ? ? ? }
? ? }調(diào)用接口,解析Json字符串并存入數(shù)據(jù)庫
通過api接口獲取json字符串
通過get(httpGet)請求獲取接口數(shù)據(jù),使用HttpClient基本分六步:
- 創(chuàng)建HttpClient實(shí)例
- 創(chuàng)建某種連接方法的實(shí)例
- 調(diào)用HttpClient實(shí)例的execute方法來執(zhí)行請求方法
- 讀取response
- 釋放連接,無論執(zhí)行方法是否成功
//創(chuàng)建httpClient實(shí)例
CloseableHttpClient client = HttpClients.createDefault();
//汽車之家api接口
String apiPath = "https://www.autohome.com.cn/ashx/index/GetHomeFindCar.ashx";
//創(chuàng)建get方法請求實(shí)例
HttpGet httpGet = new HttpGet(apiPath);
//添加表頭,text/xml表示XML格式
httpGet.addHeader("content-type","text/xml");
//調(diào)用HttpClient實(shí)例執(zhí)行GET實(shí)例,返回response
HttpResponse response = client.execute(httpGet);
//解析response,這個過程主要取決于獲取的json格式,是一個對象還是一個數(shù)組,放到后面詳解
String result = EntityUtils.toString(response.getEntity());
//釋放連接
response.close();
client.close();其中我們可以對response的狀態(tài)(state)進(jìn)行判斷,驗(yàn)證是否獲取數(shù)據(jù). 頁面請求的狀態(tài)值,分別有:200請求成功、303重定向、400請求錯誤、401未授權(quán)、403禁止訪問、404文件未找到、500服務(wù)器錯誤.
(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()方法返回保存請求狀態(tài)的StatusLine對象,getStatusCode()獲取狀態(tài)碼使用JSONArray和JSONObject解析json字符串
在解析json字符串之前,我們一定要先確定json字符串的格式,針對不同的格式要使用不同的解析方法這里列舉了一些常見的json字符串格式
例如:數(shù)值,字符串,數(shù)組,對象數(shù)組或數(shù)組對象.重點(diǎn)就在于花括號和中括號的使用,一定要注意這兩個符號,可能會導(dǎo)致json解析錯誤.
//json數(shù)值
{
"key" : 520,
"key1" : 1314
}
//json字符串
{
"key" : "我愛你",
"key1" : "一生一世"
}
//json數(shù)組
{
"key" : [520, 1314],
"key1" : [520, 3344]
}
//json對象數(shù)組
{
"我" : [
{"key": "我愛你"},
{"key1": "一生一世"}
]
}
//json數(shù)組對象
{
"我" : {
[520,1314],
["我愛你", "一生一世"]
}
}
可以看出從汽車之家獲取的json字符串是json數(shù)組格式的,所以我們要用JSONArray進(jìn)行解析,然后再對json數(shù)組進(jìn)行遍歷,獲取每一個json對象,然后對json對象進(jìn)行數(shù)據(jù)的讀取.
//將json字符串解析成json數(shù)組的形式
JSONArray jsonArray = JSONArray.parseArray(result);
//利用遍歷解析json數(shù)組,并在循環(huán)中解析每一個json對象
for (int i = 0; i < jsonArray.size(); i++) {
//將json數(shù)組解析為每一個jsonObject對象
JSONObject object=jsonArray.getJSONObject(i);
//實(shí)例化一個dao層或者domain層的對象
CarBrand Brand = new CarBrand();
//將json對象中的數(shù)據(jù)寫入實(shí)例化的對象中
//注意object讀取的字段要和json對象中的字段一樣,否則無法解析
Brand.setId(object.getInteger("id"));
Brand.setName(object.getString("name"));
Brand.setGroup(object.getString("letter"));
}將實(shí)例化對象的數(shù)據(jù)存入數(shù)據(jù)庫中
在springboot框架之中,mybatis-generator可以生成domain層的實(shí)體文件,xml文件,mapper文件和相應(yīng)的service文件,利用這個插件可以省去我們寫sql語句的時間,我們可以在service層直接調(diào)用相應(yīng)的方法.
//調(diào)用service層的add方法,直接將實(shí)例化對象寫入數(shù)據(jù)庫 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數(shù)據(jù)
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數(shù)據(jù)進(jìn)行json解析
String result = EntityUtils.toString(response.getEntity());
JSONArray jsonArray = JSONArray.parseArray(result);
for (int i = 0; i < jsonArray.size(); i++) {
//將json對象中的數(shù)據(jù)寫入實(shí)例化對象中
CarBrand carBrand = new CarBrand();
JSONObject object=jsonArray.getJSONObject(i);
carBrand.setId(object.getInteger("id"));
carBrand.setName(object.getString("name"));
carBrand.setGroup(object.getString("letter"));
//將實(shí)例化對象存入數(shù)據(jù)庫
carBrandService.add(CarBrand);
}
}
}catch (Exception e){
throw new RuntimeException(e);
}
}
}總結(jié)
以上為個人經(jīng)驗(yàn),希望能給大家一個參考,也希望大家多多支持腳本之家。
相關(guān)文章
java 快速實(shí)現(xiàn)異步調(diào)用的操作方法
這篇文章主要介紹了java 如何快速實(shí)現(xiàn)異步調(diào)用方法,今天我們就來了解下 CompletableFuture,它Java 8引入的一種功能強(qiáng)大的異步編程工具,可以用于實(shí)現(xiàn)復(fù)雜的異步操作和處理鏈?zhǔn)降漠惒饺蝿?wù),需要的朋友可以參考下2023-07-07
SpringBoot分頁查詢功能的實(shí)現(xiàn)方法
在實(shí)際的項(xiàng)目開發(fā)過程中,分頁顯示是很常見的頁面布局,所以學(xué)習(xí)如何實(shí)現(xiàn)分頁也是必要的,下面這篇文章主要給大家介紹了關(guān)于SpringBoot分頁查詢功能的實(shí)現(xiàn)方法,需要的朋友可以參考下2022-06-06
Java集合框架之List ArrayList LinkedList使用詳解刨析
早在 Java 2 中之前,Java 就提供了特設(shè)類。比如:Dictionary, Vector, Stack, 和 Properties 這些類用來存儲和操作對象組。雖然這些類都非常有用,但是它們?nèi)鄙僖粋€核心的,統(tǒng)一的主題。由于這個原因,使用 Vector 類的方式和使用 Properties 類的方式有著很大不同2021-10-10
Java并發(fā)編程之線程池實(shí)現(xiàn)原理詳解
池化思想是一種空間換時間的思想,期望使用預(yù)先創(chuàng)建好的對象來減少頻繁創(chuàng)建對象的性能開銷,java中有多種池化思想的應(yīng)用,例如:數(shù)據(jù)庫連接池、線程池等,下面就來具體講講2023-05-05

