Qt之JSON生成与解析

JSON(JavaScript Object Notation)是一种轻量级的数据交换格式。它基于JavaScript(Standard ECMA-262 3rd Edition - December 1999)的一个子集。 JSON采用完全独立于语言的文本格式,但是也使用了类似于C语言家族的习惯(包括C、C++、C#、Java、JavaScript、Perl、Python等)。这些特性使JSON成为理想的数据交换语言。易于人阅读和编写,同时也易于机器解析和生成。

常用的Json库
JsonCpp
JsonCpp是一个C++用来处理JSON数据的开发包。
网址:http://jsoncpp.sourceforge.net/.
cJSON
cJSON是一个超轻巧,携带方便,单文件,简单的可以作为ANSI-C标准的JSON解析器。
网址:http://sourceforge.net/projects/cjson/.
QJson
QJson是一个基于Qt的开发包用来将JSON数据解析成QVariant对象,JSON的数组将被映射为QVariantList实例,而其他对象映射为QVariantMap实例。
网址:http://qjson.sourceforge.net/.

关于Qt中对JSON的生成与解析,Qt5以前的版本,需要去进行单独下载、编译,才能使用。到了Qt5,提供了专门的QJsonDocument类来读取和写入JSON文档。

Qt5中JSON的生成与解析
QJsonDocument
QJsonDocument既可以从一个基于文本表示的UTF-8编码,又可以从Qt自己的二进制格式读取和写入这个文件。
JSON文档可以从它的基于文本的表示使用QJsonDocument::fromJson()转换为QJsonDocument,用.toJSON()将其转换回文字。解析器非常快速和高效,将JSON转换为二进制表示。
QJsonObject
QJsonObject类用于封装JSON对象。
JSON对象是键值对,其中键是唯一的字符串,其值由QJsonValue代表。一个QJsonObject可以从QVariantMap转换/被转换。
QJsonArray
QJsonArray类用于封装JSON数组。
一个JSON数组列表值。该列表可以通过从阵列插入和移除QJsonValue的操纵。一个QJsonArray可以从QVariantList转换为/被转换。

QJsonDocument有效解析后的文档可以使用!iSNull()判断。使用isArray()和isObject()来判断是否包含一个数组或对象。文档中包含的数组或对象可以使用array()或object()进行检索,然后读取或操纵。

示例

  • QJsonObject的生成与解析
#include <QCoreApplication>
#include <QtScript>

// JSON格式的前缀
#define J_ID        "id"
#define J_NICK      "nick"
#define J_ZHUANYE   "zhuanye"
#define J_AGE       "age"

int main(int argc, char *argv[])
{
    QCoreApplication a(argc, argv);
    // 构造QJSonObject
    QJsonObject json_object;
    json_object.insert(J_ID,        "1263");
    json_object.insert(J_NICK,      "lin");
    json_object.insert(J_AGE,       20);
    json_object.insert(J_ZHUANYE,   "ruanjiangc");
    // 转换成QByteArray
    QByteArray byte_array = QJsonDocument(json_object).toJson();

    // 这时候发送byte_array
    // 另外一端对byte_array进行解析

    // QByteArray转换成QJsonObject
    QJsonObject json_object2 = QJsonDocument::fromJson(byte_array).object();
    qDebug() << json_object2.value(J_ID).toString();
    qDebug() << json_object2.value(J_NICK).toString();
    qDebug() << json_object2.value(J_AGE).toInt();
    qDebug() << json_object2.value(J_ZHUANYE).toString();

    return a.exec();
}

这里写图片描述

  • QJsonArray的生成与解析
#include <QCoreApplication>
#include <QtScript>

// JSON格式的前缀
#define J_ID        "id"
#define J_NICK      "nick"
#define J_ZHUANYE   "zhuanye"
#define J_AGE       "age"

enum {
    TAG_LOGIN,
    TAG_LOGIN_OK,
    TAG_LOGIN_FAIL,
    TAG_REGISTER,
    TAG_REGISTER_OK,
    TAG_REGISTER_FAIL,
    TAG_FIND_BACK
};


int main(int argc, char *argv[])
{
    QCoreApplication a(argc, argv);
    // 构造QJsonObject(从数据库中读取的时候是在循环里面构造)
    QJsonObject json_object;
    json_object.insert(J_ID,        "1263");
    json_object.insert(J_NICK,      "lin");
    json_object.insert(J_AGE,       20);
    json_object.insert(J_ZHUANYE,   "ruanjiangc");
    QJsonObject json_object2;
    json_object2.insert(J_ID,        "2345");
    json_object2.insert(J_NICK,      "jin");
    json_object2.insert(J_AGE,       5);
    json_object2.insert(J_ZHUANYE,   "ruanjiangc");
    QJsonObject json_object3;
    json_object3.insert(J_ID,        "9999");
    json_object3.insert(J_NICK,      "qiu");
    json_object3.insert(J_AGE,       21);
    json_object3.insert(J_ZHUANYE,   "ruanjiangc");
    QJsonObject json_object4;
    json_object4.insert(J_ID,        "6666");
    json_object4.insert(J_NICK,      "zhao");
    json_object4.insert(J_AGE,       19);
    json_object4.insert(J_ZHUANYE,   "ruanjiangc");
    // 构造QJsonArray
    QJsonArray json_array;
    json_array.insert(0, TAG_LOGIN);
    json_array.insert(1, json_object);
    json_array.insert(2, json_object2);
    json_array.insert(3, json_object3);
    json_array.insert(4, json_object4);
    // 转换成QByteArray
    QByteArray byte_array = QJsonDocument(json_array).toJson();

    // 这时候发送byte_array
    // 另外一端对byte_array进行解析

    // QByteArray转换成QJsonArray
    QJsonParseError json_error;
    QJsonDocument parse_doucment = QJsonDocument::fromJson(byte_array, &json_error); 
    if(json_error.error == QJsonParseError::NoError) 
    {  
        if(parse_doucment.isArray())  
        {  
            QJsonArray json_array2 = parse_doucment).array();
            int tag = json_array2.at(0).toInt();
            qDebug() << "tag:" << tag;
            for(int i = 1; i < json_array2.size(); ++i) 
            {
                QJsonObject json = json_array2.at(i).toObject();
                qDebug() << json.value(J_ID).toString();
                qDebug() << json.value(J_NICK).toString();
                qDebug() << json.value(J_AGE).toInt();
                qDebug() << json.value(J_ZHUANYE).toString();
            }
        }
    }

    return a.exec();
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值