91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

Java怎么調用接口獲取json數據解析后保存到數據庫

發布時間:2023-05-06 11:37:09 來源:億速云 閱讀:289 作者:iii 欄目:開發技術

本篇內容主要講解“Java怎么調用接口獲取json數據解析后保存到數據庫”,感興趣的朋友不妨來看看。本文介紹的方法操作簡單快捷,實用性強。下面就讓小編來帶大家學習“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;
            }
        }

    調用接口,解析Json字符串并存入數據庫

    通過api接口獲取json字符串

    通過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()獲取狀態碼

    使用JSONArray和JSONObject解析json字符串

    在解析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],
                      ["我愛你", "一生一世"]
        }
    }

    Java怎么調用接口獲取json數據解析后保存到數據庫

    可以看出從汽車之家獲取的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數據解析后保存到數據庫”有了更深的了解,不妨來實際操作一番吧!這里是億速云網站,更多相關內容可以進入相關頻道進行查詢,關注我們,繼續學習!

    向AI問一下細節

    免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

    AI

    电白县| 南召县| 额济纳旗| 开远市| 凤台县| 团风县| 泽州县| 和硕县| 平顶山市| 长宁区| 巧家县| 禄劝| 普安县| 黑山县| 民丰县| 巴林左旗| 大洼县| 榆林市| 木兰县| 湘阴县| 嵊泗县| 清远市| 华宁县| 马公市| 通化市| 天长市| 辽宁省| 瑞昌市| 安徽省| 崇礼县| 略阳县| 苍溪县| 泉州市| 闻喜县| 和平区| 修文县| 怀集县| 唐山市| 正安县| 宿迁市| 辰溪县|