如何解析json字符串及返回json数据到前端
前言:最近需要实现的任务是:写若干个接口,并且接口中的请求数据是json格式,然后按照请求参数读取前端提前整理好的json数据,并且将json数据返回到服务器端。
- 主要的工具:Gson 2.8.2
- 项目支撑:springboot
- maven
0、前导——了解一下基本的json语法
JSON是一种类似 XML的语言,是用了存储和交换文本信息的语法。它的全称为JavaScript Object Notation(JavaScript 对象表示法)。与xml对比,它更小、更快,更易解析。
想要更好的解析JSON,必须能看懂JSON数据,这样就必须了解JSON语法,好在它的语法非常简单,规则如下:
JSON 语法是 JavaScript 对象表示法语法的子集。
- 数据在名称/值对中:如 "firstName" : "John"
- 数据由逗号分隔
- 花括号保存对象
- 方括号保存数组
而组成JSON的值可以为以下几种:
- 数字(整数或浮点数)
- 字符串(在双引号中)
- 逻辑值(true 或 false)
- 数组(在方括号中)
- 对象(在花括号中)
- null
1、导入Gson jar包
<!-- https://mvnrepository.com/artifact/com.google.code.gson/gson -->
<dependency>
<groupId>com.google.code.gson</groupId>
<artifactId>gson</artifactId>
<version>2.8.2</version>
</dependency>
关于Gson的详细信息可以参考:JAVA解析JSON数据
Gson 是 Google 提供的用来在 Java 对象和 JSON 数据之间进行映射的 Java 类库。可以将一个 JSON 字符串转成一个 Java 对象,或者反过来。
这是关于GSON的介绍,相对于传统的json解析,使用GSON能够极大的简化了解析流程。
2、下面提供一小段提前整理好的json数据
[
{
"zone_id": 100001,
"title": "围栏1",
"zone_geometry": {
"type": "polygon",
"apex": [ {
"lng": "113.166096",
"lat": "31.727309"
},
{
"lng": "113.222498",
"lat": "31.689881"
}
]
}
},
{
"zone_id": 100002,
"title": "围栏2",
"zone_geometry": {
"type": "polygon",
"apex": [
{
"lng": "113.462342",
"lat": "31.626034"
},
{
"lng": "113.472525",
"lat": "31.538983"
}
]
}
},
]
分析原始的json数据格式:原始的json数据整体是一个JsonArray,其次是JsonObject,内部包含有很多字段,里面再套有一层JsonObject,再往里面是JsonArray。
通常而言,遇到了一个[ ] 可以定义一个List,碰见一个{ } 可以定义一个实体类。
因此,我这里定义了三个实体类:
从外层往内层依次是:HerdCamera ZoneGeometry Apex
public class HerdCamera {
private String zone_id;
private String title;
private ZoneGeometry zoneGeometry; public String getZone_id() {
return zone_id;
} public void setZone_id(String zone_id) {
this.zone_id = zone_id;
} public String getTitle() {
return title;
} public void setTitle(String title) {
this.title = title;
} public ZoneGeometry getZoneGeometry() {
return zoneGeometry;
} public void setZoneGeometry(ZoneGeometry zoneGeometry) {
this.zoneGeometry = zoneGeometry;
} }
import java.util.List; public class ZoneGeometry {
private String type;
private List<Locations> apex; public String getType() {
return type;
} public void setType(String type) {
this.type = type;
} public List<Locations> getApex() {
return apex;
} public void setApex(List<Locations> apex) {
this.apex = apex;
} }
public class Apex {
private double lng;
private double lat; public Apex(double lng, double lat) {
super();
this.lng = lng;
this.lat = lat;
} public double getLng() {
return lng;
} public void setLng(double lng) {
this.lng = lng;
} public double getLat() {
return lat;
} public void setLat(double lat) {
this.lat = lat;
} }
3、开始依次从外往内部解析数据源
public Map<String,Object> herdcameradata() throws Exception{
String fileName = "fileName";
JsonParser parser = new JsonParser(); // 创建JSON解析器
JsonArray array = (JsonArray) parser.parse(new FileReader(fileName)); // 首先解析出来的是JsonArray Map< String, Object> result=new HashMap<>(); List<Object> herdCameras = new ArrayList<Object>(); for (int i = 0; i < array.size(); i++) {
JsonObject subObject = array.get(i).getAsJsonObject(); // 第二步获得的是JsonObject
HerdCamera herd = new HerdCamera();
herd.setZone_id(subObject.get("zone_id").getAsString()); //然后依次获取subObject中的每一个字段
herd.setTitle(subObject.get("title").getAsString());
ZoneGeometry zoneGeometry = new ZoneGeometry();
JsonObject subObject2 = subObject.getAsJsonObject("zone_geometry"); //第四步又获得一个zone_geometry的JsonObject
zoneGeometry.setType(subObject2.get("type").getAsString()); //然后获取zone_geometry内部的type对象
JsonArray array2 = subObject2.getAsJsonArray("apex"); //第五步中apex是一个jsonArray
List<Locations> locationList = new ArrayList<Locations>();
for (int j = 0; j < array2.size(); j++) {
Locations location = new Locations();
JsonObject subObject3 = array2.get(j).getAsJsonObject();
location.setLng(subObject3.get("lng").getAsString());
location.setLat(subObject3.get("lat").getAsString());
locationList.add(location);
}
zoneGeometry.setApex(locationList);
herd.setZoneGeometry(zoneGeometry);
herdCameras.add(herd);
} result.put("cameras",herdCameras );
return result;
}
4、结束
到现在,所有的解析都已经基本完成,但配合着controller中的映射就可以在前端获取到相关的数据。
下面给出我获取到的情况:
如何解析json字符串及返回json数据到前端的更多相关文章
- HttpServletResponse 返回的json数据不是json字符串,而是json对象
今天在改一个bug 情况: 在spring boot中写了一个类Result ,用来统一封装 各个API响应结果 , 其中重写了toString()方法来返回 json字符串 . 在正常情况下,从其它 ...
- python字典转化成json格式。JSONEncoder和JSONDecoder两个类来实现Json字符串和dict类型数据的互相转换
遇到问题:进行Webservice接口测试时,对接口入参数据进行了处理,变成了dict格式,去进行接口请求报错. 需要转成成json格式,双引号去扩. 如下: 更改代码: # 在Python标准库的j ...
- json字符串转化为json对象and 对象转化为 json字符串
第一种方法: var data =evel('('+jsonstr+')') 解析: 这种方法是常用的方法, 即动态执行 javascript代码 在堆中存放数据. 存在安全问题. 第二种方法: ...
- json字符串转换成json对象,json对象转换成字符串,值转换成字符串,字符串转成值
一.json相关概念 json,全称为javascript object notation,是一种轻量级的数据交互格式.采用完全独立于语言的文本格式,是一种理想的数据交换格式. 同时,json是jav ...
- 特殊字符导致json字符串转换成json对象出错
在对数据库取出来的数据(特别是描述信息)里面含有特殊字符的话,使用JSON.parse将json字符串转换成json对象的时候会出错,主要是双引号,回车换行等影响明显,左尖括号和右尖括号也会导致显示问 ...
- JavaScript:将key和value不带双引号的JSON字符串转换成JSON对象的方法
遇到相关的问题,花了两天的时间来解决,深感来之不易,所以做如下的总结,希望遇到此问题的码农能更快的找到解决办法! var jsonArr= [{col:TO_CHAR(HZRQ,'YYYYMM'),t ...
- js将json字符串转化成json对象的方法
js将json字符串转化成json对象的方法: JSON.parse(jsonObject)
- nodejs将JSON字符串转化为JSON对象
如何将JSON字符串转化为JSON对象? JSON.parse(str) JSON是javascript的一个内置对象,提供了转换JSON对象与字符串互相转换的方法: 问题来了,道理我都懂 ...
- json字符串转成 json对象 json对象转换成java对象
import com.alibaba.fastjson.JSONArray;import com.alibaba.fastjson.JSONObject; 依赖包 <dependency> ...
随机推荐
- python__new__与__init__的区别
__new__ __init__区别 1 class A(object): 2 def __init__(self,*args, **kwargs): 3 print "init A&quo ...
- PHP IN_ARRAY 函数 使用需要注意的地方
今天 看PPChttp://bbs.phpchina.com/thread-171993-1-7.html 这个问题. 其实关键还是因为 php是弱类型语言,php进行比较的时候 最好还是使用stri ...
- Fastify 系列教程一 (路由和日志)
Fastify 系列教程: Fastify 系列教程一 (路由和日志) Fastify 系列教程二 (中间件.钩子函数和装饰器) Fastify 系列教程三 (验证.序列化和生命周期) Fastify ...
- [转]vue数据绑定(数据,样式,事件)
1.mounted 与 methods 与 computed 与 watched区别 From:https://blog.csdn.net/qinlulucsdn/article/details/80 ...
- opencv3.2.0 分离颜色通道&多通道图像混合
##名称:分离颜色通道&多通道图像混合 ##平台:QT5.7.1+OpenCV3.2.0 ##时间:2017年12月11日 /***************创建QT控制台程序********* ...
- elixir 基础数据结构
Elixir中的一些基础的数据结构:整数,浮点数,字符串,原子,列表,元组 整数,浮点数,字符串 跟其他语言差不多 原子:名字为值的常量 在ruby类似Symbols 在erlang是用大写 ...
- zookeeper应用 - FIFO 队列 分布式队列
使用ZooKeeper实现的FIFO队列,这个队列是分布式的. package fifo; import java.util.Collections; import java.util.List; i ...
- maven与ide工具的整合
maven与myeclipse的整合 1 点击window会出现 2>选择 preferences
- Angularjs 表格插件的使用
对于相关的table组件可以使用:UI Grid (ng-grid),ng-table,smart table,Angular-Datatables,tablelite,kendo-ui中的grid. ...
- windows 命令行使用p4
首先,p4的命令行真的恶心,要不是非要用我一定换成git(逃) 参考网站:https://www.perforce.com/manuals/v15.1/cmdref/p4_add.html 全程尝试各 ...