ホームページ > Java > &#&チュートリアル > Java はインターフェイスをどのように呼び出して JSON データを取得し、解析後にデータベースに保存しますか?

Java はインターフェイスをどのように呼び出して JSON データを取得し、解析後にデータベースに保存しますか?

WBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWB
リリース: 2023-05-14 10:58:05
転載
2176 人が閲覧しました

    Java はインターフェースを呼び出して json データを取得し、データベースに保存します

    1. 独自に定義したインターフェース URL を yml ファイルに構成します

    1

    2

    //自己定义的JSON接口URL

    blacklist_data_url: 接口URL

    ログイン後にコピー

    2 .Controller

    1

    2

    3

    4

    5

    6

    7

    8

    9

    10

    /**

     * @Title: 查询

     * @Description: 查询车辆的记录

     * @Author: 半度纳

     * @Date: 2022/9/27 17:33

     */

    @GetMapping("/Blacklist")

    public void selectBlacklist(){

        boolean a = imBuBlacklistService.selectBlacklist();//调用业务层方法

    }

    ログイン後にコピー

    3 にリクエストメソッドとパスを追加 Service にメソッド

    1

    2

    3

    4

    5

    6

    7

    8

    /**

     * @Title: 查询

     * @Description: 查询车辆的记录

     * @Author: 半度纳

     * @Date: 2022/9/27 17:33

     * @return

     */

    public boolean selectBlacklist();//返回值类型没要求

    ログイン後にコピー

    4 を追加 ServiceImpl にメソッド

    1

    2

    3

    4

    5

    6

    7

    8

    9

    10

    11

    12

    13

    14

    15

    16

    17

    18

    19

    20

    21

    22

    23

    24

    25

    26

    27

    28

    29

    30

    31

    32

    33

    34

    35

    36

    37

    38

    39

    40

    41

    42

    43

    44

    45

    46

    47

    48

    49

    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 を使用するには、基本的に 6 つの手順があります。 :

    • HttpClient インスタンスの作成

    • 特定の接続メソッドのインスタンスの作成

    • Callリクエスト メソッドを実行するための HttpClient インスタンスの実行メソッド

    • 応答の読み取り

    • 実行メソッドが成功したかどうかに関係なく、接続を解放します。 or not

    1

    2

    3

    4

    5

    6

    7

    8

    9

    10

    11

    12

    13

    14

    15

    //创建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();

    ログイン後にコピー

    レスポンスに対してステータス(状態)を判断してデータが取得できたかどうかを確認します。ページリクエストのステータス値は、200リクエスト成功、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)

    1

    2

    3

    if (response.getStatusLine().getStatusCode() == HttpStatus.SC_OK) {

        String result = EntityUtils.toString(response.getEntity());//解析response

    }//getStatusLine()方法返回保存请求状态的StatusLine对象,getStatusCode()获取状态码

    ログイン後にコピー

    JSONArray と JSONObject を使用して json 文字列を解析する

    JSON 文字列を解析する前に、まず次の形式を決定する必要があります。 json 文字列。形式ごとに異なる解析方法を使用する必要があります。一般的な json 文字列形式をいくつか示します

    例: 数値、文字列、配列、オブジェクト配列、または配列オブジェクト。重要な点は、次の使用です。中括弧と角括弧。この 2 つの記号は json 解析エラーを引き起こす可能性があるので注意してください。

    1

    2

    3

    4

    5

    6

    7

    8

    9

    10

    11

    12

    13

    14

    15

    16

    17

    18

    19

    20

    21

    22

    23

    24

    25

    26

    27

    28

    29

    //json数值

    {

        "key" : 520,

        "key1" : 1314

    }   

    //json字符串

    {

        "key" : "我爱你",

        "key1" : "一生一世"

    }

    //json数组

    {

        "key" : [520, 1314],

        "key1" : [520, 3344]

    }

    //json对象数组

    {

        "我" : [

                      {"key": "我爱你"},

                      {"key1": "一生一世"}

        ]

    }

    //json数组对象

    {

        "我" : {

                      [520,1314],

                      ["我爱你", "一生一世"]

        }

    }

    ログイン後にコピー

    Java はインターフェイスをどのように呼び出して JSON データを取得し、解析後にデータベースに保存しますか?

    Autohome から取得した json 文字列であることがわかります。は json 配列形式であるため、JSONArray を使用して解析し、json 配列を走査する必要があります。各 json オブジェクトを取得し、json オブジェクトからデータを読み取ります。

    1

    2

    3

    4

    5

    6

    7

    8

    9

    10

    11

    12

    13

    14

    //将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 はドメイン層エンティティ ファイル、xml ファイル、マッパー ファイル、および対応するサービス ファイルを生成できます。このプラグインを使用すると、SQL ステートメントを作成する時間を節約できます。サービス層の対応するメソッドを直接呼び出すことができます。

    1

    2

    //调用service层的add方法,直接将实例化对象写入数据库

    CarBrandService.add(Brand);

    ログイン後にコピー

    完全なコードは次のとおりです

    1

    2

    3

    4

    5

    6

    7

    8

    9

    10

    11

    12

    13

    14

    15

    16

    17

    18

    19

    20

    21

    22

    23

    24

    25

    26

    27

    28

    29

    30

    31

    32

    33

    34

    35

    36

    37

    38

    39

    40

    41

    42

    43

    44

    45

    46

    47

    48

    49

    50

    51

    52

    53

    54

    55

    56

    57

    58

    59

    60

    61

    62

    63

    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 データを取得し、解析後にデータベースに保存しますか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

    関連ラベル:
    このウェブサイトの声明
    この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
    人気のチュートリアル
    詳細>
    最新のダウンロード
    詳細>
    ウェブエフェクト
    公式サイト
    サイト素材
    フロントエンドテンプレート