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实例,返回responsehttpresponse 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], ["我爱你", "一生一世"] }}
可以看出从汽车之家获取的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; @servicepublic 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数据解析后保存到数据库的详细内容。