首页 > 编程 > Java > 正文

关于Java跨域Json字符转类对象的方法示例

2019-11-26 10:49:16
字体:
来源:转载
供稿:网友

前言

JSON是JavaScript Object Notation的缩写,是一种轻量级的数据交换形式,是一种XML的替代方案,而且比XML更小,更快而且更易于解析。因为JSON描述对象的时候使用的是JavaScript语法,它是语言和平台独立的,并且这些年许多JSON的解析器和类库被开发出来。

JSON具有以下这些形式:

对象是一个无序的“‘名称/值'对”集合。一个对象以“{”(左括号)开始,“}”(右括号)结束。每个“名称”后跟一个“:”(冒号);“‘名称/值' 对”之间使用“,”(逗号)分隔。

值的有序列表(An ordered list of values)。在大部分语言中,它被实现为数组(array),矢量(vector),列表(list),序列(sequence)。

这些都是常见的数据结构。目前,绝大部分编程语言都以某种形式支持它们。这使得在各种编程语言之间交换同样格式的数据成为可能。

对于从其他服务器的url获得数据,我们一般都为json数据传输,比如服务器B要从服务器A的url获得分页信息,得到json字符后如果可以方便快捷操作要转为自己的java对象。

在此我试过三种转json的第三方,一种google的gson,这种好像无法转成功,一直报json格式错误,但校验一直通过正确,尝试失败。第二种是net.sf.json的,这种就是无报错,但是对象的值一直为空。只有json-simple可以成功转对象

解析json

首先,我们要解析json,查看json是否为标准的json格式,我们可以在网上的很多在线格式化查看json,解析json为对象一般都换汤不换药。

第一:就是要知道json结构,这里我先开启服务器A从他的url得到一串json数据。

把复制json数据把它扔在格式化工具可以很清楚的看出结构:

{ "eventList": [ {  "id": 1030,  "eventId": "1508779115818499700",  "createTime": 1508779115000,  "endTime": 1508865480000,  "eventContent": "123",  "openid": "o4eWZ06xzHW6mc2gMZMYVDEtx1zk" }, {  "id": 1029,  "eventId": "1508382907251660498",  "createTime": 1508382906000,  "endTime": 1508383020000,  "eventContent": "ahhhhh",  "openid": "o4eWZ06xzHW6mc2gMZMYVDEtx1zk" }, {  "id": 1028,  "eventId": "1508308708414580378",  "createTime": 1508308721000,  "endTime": 1508309040000,  "eventContent": "30",  "openid": "o4eWZ06xzHW6mc2gMZMYVDEtx1zk" }, {  "id": 1027,  "eventId": "1508308463330664814",  "createTime": 1508308480000,  "endTime": 1508308560000,  "eventContent": "28",  "openid": "o4eWZ06xzHW6mc2gMZMYVDEtx1zk" }, {  "id": 1026,  "eventId": "1508308463017144213",  "createTime": 1508308479000,  "endTime": 1508308560000,  "eventContent": "27",  "openid": "o4eWZ06xzHW6mc2gMZMYVDEtx1zk" } ], "page": "1", "size": "5", "isHasPage": "1"}

第二:根据结构创建对应的实体类

import com.yhn.consumer.entity.Event;import lombok.Data;import org.json.simple.JSONObject;import java.io.Serializable;import java.util.List;@Datapublic class EventVO implements Serializable{ private List<Event> eventList; private String page; private String size; private String isHasPage; public EventVO(JSONObject object){ //构造器方法给对象赋值 eventList = (List<Event>)object.get("eventList"); page = (String)object.get("page"); size = (String)object.get("size"); isHasPage = (String)object.get("isHasPage"); }}

因为是内嵌结构,下面这个是private List<Event> eventList中的Event类;

import lombok.Data;import org.hibernate.annotations.DynamicUpdate;import javax.persistence.Entity;import javax.persistence.GeneratedValue;import javax.persistence.Id;import java.io.Serializable;import java.util.Date;@Entity@Data@DynamicUpdate //自动更新时间字段public class Event implements Serializable { //这是EventVO里List中的Event @Id @GeneratedValue private Integer id; //排序作用 private String eventId; //事件id private Date createTime; //创建时间 private Date endTime; //更新时间 private String eventContent; //提醒事件内容 private String openid; //用户id}

测试类

接下来结构也写好了,将在服务器B写单元测试看看是否能够成功赋值

 @Test public void clientDemo()throws Exception { StringBuilder json = new StringBuilder();  URL urlObject = new URL("http://127.0.0.1/meetingSign/test/server?openid=o4eWZ06xzHW6mc2gMZMYVDEtx1zk&page=2&size=5"); //指定URL  HttpURLConnection uc = (HttpURLConnection) urlObject   .openConnection(); //开启连接  BufferedReader in = new BufferedReader(new InputStreamReader(uc.getInputStream(), "utf-8"));  String inputLine = null;  while ((inputLine = in.readLine()) != null) {  json.append(inputLine); //拼接json  }  in.close();  uc.disconnect();  System.out.println(json); //查看是否拿到。  //去除可能含编码UTF-8等,因为可能含有Bom头文件。  String result = formatString(json.toString());  JSONParser parser=new JSONParser();  org.json.simple.JSONObject data = new org.json.simple.JSONObject();  data = (org.json.simple.JSONObject) parser.parse(result);  EventVO eventVO = new EventVO(data); //把值传进去  log.info("eventVO={}",eventVO); } /** * 去除bom报头 */ public static String formatString(String s) { if (s != null) {  s = s.replaceAll("/ufeff", ""); } return s; }

测试结果

是成给对象赋值了


总结

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,如果有疑问大家可以留言交流,谢谢大家对武林网的支持。

发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表