整合营销服务商

电脑端+手机端+微信端=数据同步管理

免费咨询热线:

JAVA实现生成多层JSON格式数据(含源码-三层样

JAVA实现生成多层JSON格式数据(含源码-三层样例)

SON

JSON(JavaScriptObject Notation, JS 对象标记) 是一种轻量级的数据交换格式。它基于ECMAScript规范的一个子集,采用完全独立于编程语言的文本格式来存储和表示数据。简洁和清晰的层次结构使得 JSON 成为理想的数据交换语言。 易于人阅读和编写,同时也易于机器解析和生成,并有效地提升网络传输效率。

下面java生成JSON数据

import net.sf.json.JSONArray;

import net.sf.json.JSONObject;

public class CopyOfJsonTest {

/**

* 生成多层json格式数据

* 2017年4月28日 14:53:21

* @param args

*/

public static void main(String[] args) {

JSONArray jsArray=new JSONArray();

JSONObject j3=new JSONObject();

j3.put(第三层1, 1);

j3.put(第三层2, 2);

j3.put(第三层3, 3);

jsArray.add(j3);

JSONArray jsArra2=new JSONArray();

JSONObject j2=new JSONObject();

j2.put(第二层1, 1);

j2.put(第二层2, 2);

j2.put(第二层3, jsArray);

jsArra2.add(j2);

JSONObject j1=new JSONObject();

j1.put(第一层1, 1);

j1.put(第一层2, j2);

j1.put(第一层3, jsArra2);

System.out.println(j1.toString());

}

}

打印出的数据格式是

感谢大家关注

“点读微讯”

. JSON 是什么?

  • JSON 指的是 JavaScript 对象表示法(JavaScript Object Notation)
  • JSON 是轻量级的文本数据交换格式
  • JSON 独立于语言:JSON 使用 Javascript语法来描述数据对象,但是 JSON 仍然独立于语言和平台。JSON 解析器和 JSON 库支持许多不同的编程语言。 目前非常多的动态(PHP,JSP,.NET)编程语言都支持JSON。
  • JSON 具有自我描述性,更易理解

2. JSON 的语法规则是怎样的?

  • JSON 语法是 JavaScript 对象表示语法的子集。
    • 数据在名称/值对中
    • 数据由逗号分隔
    • 大括号 {} 保存对象
    • 中括号 [] 保存数组,数组可以包含多个对象
{
    "name": "xdr630",
    "favorite": "programming"
}

3. JSON 和 XML

JSON常被拿来与XML做比较,因为JSON 的诞生本来就多多少少要有取代XML的意思。相比 XML,JSON的优势如下:

  • 没有结束标签,长度更短,读写更快
  • 能够直接被JavaScript解释器解析
  • 可以使用数组

两者比较

  • JSON:
{
    "name":"兮动人",
    "age":22,
    "fruits":["apple","pear","grape"]
}
  • XML:
<root>
    <name>兮动人</name>
    <age>22</age>
    <fruits>apple</fruits>
    <fruits>pear</fruits>
    <fruits>grape</fruits>
</root>

4. JSON的解析和生成(JSON 和 JS 对象互转)

  • 在JavaScript中,有两个方法与此相关: JSON.parseJSON.stringify
    JSON 和 JS 对象互转
  1. 要实现从JSON字符串转换为JS对象,使用 JSON.parse() 方法:
<script>
    var str='{"name": "兮动人","age":22}';
    var obj=JSON.parse(str);
    console.log(obj);
</script>

要实现从JS对象转换为JSON字符串,使用 JSON.stringify() 方法:

<script>
    var str='{"name": "兮动人","age":22}';
    var obj=JSON.parse(str);
    console.log(obj);
    var jsonstr=JSON.stringify(obj);
    console.log(jsonstr);
</script>

5、JSON格式规定

5.1、对象(0bject)

对象用大括号(“{}”)括起来,大括号里是一系列的“名称/值对”,请看概念图。

两个并列的数据之间用逗号(“,”)隔开,注意两点:

使用英文的逗号(“,”),不要用中文的逗号(“”)

最后一个“名称/值对“之后不要加逗号

5.2、数组(Array)

  • 数组表示一系列有序的值,用方括号(“[]”)包围起来,并列的值之间用逗号分隔,请看概念图。

例如,以下的数组是合法的:

[1,2,"three","four",true,false,null,[1,2],{"name":"兮动人"}]

5.3、名称/值对(Name/Value)

  • 名称(Name)是一个字符串,要用双引号括起来,不能用单引号也不能没有引号,这一点与JavaScript不同。
  • 值的类型只有七种:字符串(string)、数值(number)、对象(object)、数组(array), true、false、null不能有这之外的类型,例如undefined、函数等。请看概念图。

字符串(string)的规则如下:

  1. 英文双引号括起来,不能用单引号,也不能没有。
  2. 字符串中不能单独出现双引号()和右斜杠(“\“)。
  3. 如果要打双引号或右斜杠,需要使用“右斜杠+字符”的形式,例如\”\,其它的转义字符也是如此字符串的概念图。

6、字符串转化成对象



  • 解析:是指将符合JSON 语法规则的字符串转换成对象的过程。
  • 不同的编程语言都提供了解析JSON字符串的方法,在这里主要讲解JavaScript中的解析方法。主要有三种:
  1. 使用eval()
  2. 使用JSON.parse()
  3. 使用第三方库,例如JQuery等

6.1、 eval()

  • eval()函数的参数是一个字符串,其作用是直接执行其中的 JavaScript代码。

案例:eval()解析字符串

<script>
  var str="console.log('hello')";
  eval(str);
</script>
  • eval 解析字符串的结果:

  • eval()能够解析JSON字符串。从这里也可以看得出,JSON 和JavaScript是高度嵌合的。
  • 案例:eval()解析JSON字符串
<script>
  var str='{"name":"兮动人","age":22}';
  var obj=eval("("+str+")");
  console.log(obj)
</script>
  • 但是,现在已经很少直接使用eval()来解析了,如果您的浏览器版本真的是很旧,可能才需要这个方法。此外,eval()是一个相对危险的函数,因为字符串中可能含有未知因素。在这里,作为学习,还是要知道这也是一种方法。
  • 请注意 eval()的参数,在字符串两旁加了括号,这是必须的,否则会报错。
  • 因为JSON字符串是被大括号(“{}”)包围的,直接放到 eval()会被当成语句块来执行,因此要在两旁加上括号,使其变成表达式。

6.2、JSON. parse()

  • 现在绝大多数浏览器都以支持JSON.parse()是推荐使用的方式
  • 如果输入了不符合规范的字符串,会报错。

案例:JSON字符串转换为JS对象

<script>
    var str='{"name":"兮动人","age":22}';
    var obj=JSON.parse(str)
    console.log(obj)
</script>

  • JSON.parse()可以有第二个参数,是一个函数。此函数有两个参数:name和value,分别代表名称和值。当传入一个JSON字符串后,JSON的每一组名称/值对都要调用此函数。该函数有返回值,返回值将赋值给当前的名称(name)。
  • 利用第二个参数,可以在解析JSON字符串的同时对数据进行一些处理。

案例:

<script>
    var str='{"name":"兮动人","age":22}';
    var obj=JSON.parse(str,fun);
    function fun(name,value){
        console.log(name+":"+value);
        return value
    }
    console.log(obj)
</script>

可以做判断处理,当JSON字符串的 name=age 时,设置age的value=14

ML 曾经是各种应用的配置和传输的首选方式。但是现在 XML 遇到了一个强劲的对手:JSON。我们可以在这里看到有关 JSON 的语法。总体来说,JSON 的数据比 XML 更紧凑,在传输效率上也要优于 XML。不过 JSON 数据的层次化表达不及 XML,至少不如 XML 那样突出。不过这并不会阻止 JSON 的广泛应用。

一个典型的 JSON 文档可以像下面的例子:

{
  "encoding" : "UTF-8",
  "plug-ins" : [
      "python",
      "c++",
      "ruby"
      ],
  "indent" : { "length" : 3, "use_space" : true }
}

JSON 的全称是 JavaScript Object Notation,与 JavaScript 密不可分。熟悉 JavaScript 的童鞋马上就会发现,JSON 的语法就是 JavaScript 对象声明的语法。JSON 文档其实就是一个 JavaScript 对象,因而也称为 JSON 对象,以大括号作为起止符,其实质是不排序的键值对,其中键要求是 string 类型,值可以是任意类型。比如上面的示例,键 encoding 的值是字符串 UTF-8;键 plug-ins 的值是一个数组类型,在 JSON 中,数组以中括号表示,这个数组是一个字符串列表,分别有 python、c++ 和 ruby 三个对象;键 indent 的值是一个对象,这个对象有两个属性,length=3,use_space=true。

对于 JSON 的解析,我们可以使用 QJson 这个第三方库。QJson 可以将 JSON 数据转换为 QVariant 对象,将 JSON 数组转换成 QVariantList 对象,将 JSON 对象转换成 QVariantMap 对象。我们在这里使用 git clone 出 QJson 的整个代码。注意 QJson 没有提供链接库的 pro 文件,因此我们只需要将所有源代码文件添加到我们的项目即可(如同这些文件是我们自己写的一样)。接下来就可以使用 QJson 读取 JSON 内容:

#include "parser.h"
//////////
QJson::Parser parser;
bool ok;

QString json("{"
        "\"encoding\" : \"UTF-8\","
        "\"plug-ins\" : ["
        "\"python\","
        "\"c++\","
        "\"ruby\""
        "],"
        "\"indent\" : { \"length\" : 3, \"use_space\" : true }"
        "}");
QVariantMap result=parser.parse(json.toUtf8(), &ok).toMap();
if (!ok) {
    qFatal("An error occurred during parsing");
    exit (1);
}

qDebug() << "encoding:" << result["encoding"].toString();
qDebug() << "plugins:";

foreach (QVariant plugin, result["plug-ins"].toList()) {
    qDebug() << "\t-" << plugin.toString();
}

QVariantMap nestedMap=result["indent"].toMap();
qDebug() << "length:" << nestedMap["length"].toInt();
qDebug() << "use_space:" << nestedMap["use_space"].toBool();

将 JSON 对象转换成 QVariant 对象很简单,基本只需要下面几行:

// 1. 创建 QJson::Parser 对象
QJson::Parser parser;

bool ok;
// 2. 将 JSON 对象保存在一个对象 json 中,进行数据转换
QVariant result=parser.parse (json, &ok);

QJson::Parser::parse() 函数接受两个参数,第一个参数是 JSON 对象,可以是 QIODevice * 或者是 QByteArray;第二个参数是转换成功与否,如果成功则被设置为 true。函数返回转换后的 QVariant 对象。注意我们转换后的对象其实是一个 QVariantMap 类型,可以像 QMap 一样使用重载的 [] 获取键所对应的值。另外,由于 result [“plug-ins”] 是一个 QVariantList 对象(因为是由 JSON 数组返回的),因而可以调用其 toList() 函数,通过遍历输出每一个值。

【领QT开发教程学习资料,点击下方链接莬费领取↓↓,先码住不迷路~】

点击→领取Qt开发(视频教程+文档+代码+项目实战)

如果需要将 QVariant 生成 JSON 对象,我们则使用 QJson::Serializer 对象。例如:

QVariantList people;

QVariantMap bob;
bob.insert("Name", "Bob");
bob.insert("Phonenumber", 123);

QVariantMap alice;
alice.insert("Name", "Alice");
alice.insert("Phonenumber", 321);

people << bob << alice;

QJson::Serializer serializer;
bool ok;
QByteArray json=serializer.serialize(people, &ok);

if (ok) {
    qDebug() << json;
} else {
    qCritical() << "Something went wrong:" << serializer.errorMessage();
}

QJson::Serializer 和前面的 QJson::Parser 的用法相似,只需要调用 QJson::Serializer::serialize() 即可将 QVariant 类型的数据转换为 JSON 格式。其返回值是 QByteArray 类型,可以用于很多其它场合。

上面是 QJson 的主要使用方法。其实 QJson 还提供了另外一个类 QObjectHelper,用于 QVariant 和 QObject 之间的转换。注意我们上面所说的 QJson 的转换需要的是 QVariant 类型的数据,无论是转换到 JSON 还是从 JSON 转换而来。但是通常我们在应用程序中使用的是 QObject 及其子类。QObjectHelper 提供了一个工具函数,完成 QVariant 和 QObject 之间的转换。例如我们有下面的类:

class Person : public QObject
{
  Q_OBJECT

  Q_PROPERTY(QString name READ name WRITE setName)
  Q_PROPERTY(int phoneNumber READ phoneNumber WRITE setPhoneNumber)
  Q_PROPERTY(Gender gender READ gender WRITE setGender)
  Q_PROPERTY(QDate brithday READ brithday WRITE setBrithday)
  Q_ENUMS(Gender)

  public:
    Person(QObject* parent=0);
    ~Person();

    QString name() const;
    void setName(const QString& name);

    int phoneNumber() const;
    void setPhoneNumber(const int phoneNumber);

    enum Gender {Male, Female};
    void setGender(Gender gender);
    Gender gender() const;

    QDate brithday() const;
    void setBrithday(const QDate& dob);

  private:
    QString m_name;
    int m_phoneNumber;
    Gender m_gender;
    QDate m_dob;
};

那么,我们可以使用下面的代码将 Person 类进行 JSON 序列化:

Person person;
person.setName("Flavio");
person.setPhoneNumber(123456);
person.setGender(Person::Male);
person.setDob(QDate(1982, 7, 12));

QVariantMap variant=QObjectHelper::qobject2qvariant(&person);
QJson::Serializer serializer;
qDebug() << serializer.serialize( variant);

以及: