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();
}