Heim >Java >javaLernprogramm >Wie ruft Java die Schnittstelle auf, um JSON-Daten abzurufen und nach dem Parsen in der Datenbank zu speichern?
1. Konfigurieren Sie Ihre eigene definierte Schnittstellen-URL in der YML-Datei
//自己定义的JSON接口URL blacklist_data_url: 接口URL
. Fügen Sie die Anforderungsmethode und den Pfad zum Controller hinzu 3. Fügen Sie es zur Service-Methode
/** * @Title: 查询 * @Description: 查询车辆的记录 * @Author: 半度纳 * @Date: 2022/9/27 17:33 */ @GetMapping("/Blacklist") public void selectBlacklist(){ boolean a = imBuBlacklistService.selectBlacklist();//调用业务层方法 }
hinzu. Implementieren Sie die Methode
/** * @Title: 查询 * @Description: 查询车辆的记录 * @Author: 半度纳 * @Date: 2022/9/27 17:33 * @return */ public boolean selectBlacklist();//返回值类型没要求
in ServiceImpl, um die Schnittstelle aufzurufen, den JSON-String zu analysieren und in der Datenbank zu speichern.
Erstellen Sie eine HttpClient-Instanz.
Erstellen Sie eine Instanz einer bestimmten Verbindungsmethode.
Rufen Sie die Ausführungsmethode der HttpClient-Instanz auf, um sie auszuführen die Anforderungsmethode
Lesen Sie die Antwort
Geben Sie die Verbindung frei, unabhängig davon, ob die Ausführungsmethode erfolgreich ist
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; } }
Wir können den Status der Antwort beurteilen und überprüfen, ob die Daten erhalten wurden. Die Statuswerte der Seitenanforderung sind: 200 Anforderung erfolgreich, 303 Umleitung, 400 Anforderungsfehler, 401 keine Autorisierung, 403 Zugriff verboten, 404 Datei nicht gefunden, 500 Serverfehler.
//创建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();
Verwenden Sie JSONArray und JSONObject, um JSON-Strings zu analysierenBevor wir den JSON-String analysieren, müssen wir zunächst das Format des JSON-Strings bestimmen. und verwenden Sie verschiedene Analysemethoden für verschiedene Formate. Zum Beispiel: numerischer Wert, Zeichenfolge, Array, Objektarray oder Array-Objekt. Der entscheidende Punkt ist die Verwendung von geschweiften Klammern und eckigen Klammern Achten Sie auf diese beiden Symbole, da diese zu JSON-Parsing-Fehlern führen können JSON-Array, um jedes JSON-Objekt abzurufen und dann die Daten aus dem JSON-Objekt zu lesen.
if (response.getStatusLine().getStatusCode() == HttpStatus.SC_OK) { String result = EntityUtils.toString(response.getEntity());//解析response }//getStatusLine()方法返回保存请求状态的StatusLine对象,getStatusCode()获取状态码
Im Springboot-Framework kann Mybatis-Generator Entitätsdateien auf Domänenebene und XML-Dateien generieren , Mapper-Dateien und entsprechende Servicedateien können uns sparen. Beim Schreiben von SQL-Anweisungen können wir die entsprechende Methode direkt in der Serviceschicht aufrufen.
//json数值 { "key" : 520, "key1" : 1314 } //json字符串 { "key" : "我爱你", "key1" : "一生一世" } //json数组 { "key" : [520, 1314], "key1" : [520, 3344] } //json对象数组 { "我" : [ {"key": "我爱你"}, {"key1": "一生一世"} ] } //json数组对象 { "我" : { [520,1314], ["我爱你", "一生一世"] } }
Der vollständige Code lautet wie folgt
//将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")); }
Das obige ist der detaillierte Inhalt vonWie ruft Java die Schnittstelle auf, um JSON-Daten abzurufen und nach dem Parsen in der Datenbank zu speichern?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!