Jsoncpp Compiler、Programming
catalog
1. C++ jsoncpp简介
2. Jsoncpp的下载与编译
3. Linux Jsoncpp的SDK编译 & 简单实例
4. Windows Jsoncpp的SDK编译 & 简单实例
1. C++ jsoncpp简介
jsoncpp是c++解析JSON串常用的解析库之一。其常用的类有
1. Json::Value: jsoncpp中最基本、最重要的类,用于表示各种类型的对象,jsoncpp支持的对象类型可见Json::ValueType枚举值
2. Json::Reader: 用于读取、将字符串转换为Json::Value对象
3. Json::Writer: 一个纯虚类,并不能直接使用。在此我们使用Json::Writer的子类
1) Json::FastWriter
2) Json::StyledWriter
3) Json::StyledStreamWriter
Jsoncpp中所有对象、类名都在namespace json中,包含json.h即可
Relevant Link:
2. Jsoncpp的下载与编译
1. 从gitbub上下载源代码: https://codeload.github.com/open-source-parsers/jsoncpp/zip/master
2. unzip master
3. cd jsoncpp-master
4. scons platform=linux-gcc
//gcc版本是4.8的,上面的命令执行完后,会在./libs/linux-gcc-4.8目录下面生成库文件
-rw-r--r-- 1 root root 1068476 Jun 29 14:51 libjson_linux-gcc-4.8_libmt.a
-rwxr-xr-x 1 root root 588508 Jun 29 14:51 libjson_linux-gcc-4.8_libmt.so*
/*
.so需要随主程序下发到客户端机器上,并添加到客户端的include搜索路径中
.a可以使用静态编译直接集成编译到主程序中
*/
Relevant Link:
https://github.com/open-source-parsers/jsoncpp
3. Linux Jsoncpp的SDK编译 & 简单实例
0x1: 反序列化Json对象字符串
jscpp1.cpp
#include <iostream>
#include <string>
#include "json/json.h"
int main(void)
{
std::string strValue = "{\"key1\":\"value1\",\"array\":[{\"key2\":\"value2\"},{\"key2\":\"value3\"},{\"key2\":\"value4\"}]}";
Json::Reader reader;
Json::Value value;
if (reader.parse(strValue, value))
{
std::string out = value["key1"].asString();
std::cout << out << std::endl;
const Json::Value arrayObj = value["array"];
for (int i = 0; i<arrayObj.size(); i++)
{
out = arrayObj[i]["key2"].asString();
std::cout << out;
if (i != arrayObj.size() - 1)
std::cout << std::endl;
}
}
return 0;
}
编译链接
g++ -o jsoncpp1 jscpp1.cpp -I/zhenghan/jsonCPP/jsoncpp-master/include /zhenghan/jsonCPP/jsoncpp-master/libs/linux-gcc-4.8/libjson_linux-gcc-4.8_libmt.a
0x2: 序列化构建Json对象
先构建一个Json对象,此Json对象中含有数组,然后把Json对象序列化成字符串
jscpp2.cpp
#include <iostream>
#include <string>
#include "json/json.h"
int main(void)
{
Json::Value root;
Json::Value arrayObj;
Json::Value item;
for (int i = 0; i < 10; i ++)
{
item["key"] = i;
arrayObj.append(item);
}
root["key1"] = "value1";
root["key2"] = "value2";
root["array"] = arrayObj;
//root.toStyledString();
std::string out = root.toStyledString();
std::cout << out << std::endl;
return 0;
}
编译链接
g++ -o jsoncpp2 jsoncpp2.cpp -I/zhenghan/jsonCPP/jsoncpp-master/include /zhenghan/jsonCPP/jsoncpp-master/libs/linux-gcc-4.8/libjson_linux-gcc-4.8_libmt.a
4. Windows Jsoncpp的SDK编译 & 简单实例
0x1: 编译链接
1. 下载jsoncpp
2. 解压
3. 打开jsoncpp-src -> makefiles -> msvc2010 -> jsoncpp.sln
4. 分别选择debug/released模式
5. 在"解决方案资源管理器"中右击lib_json,选择 -> 仅用于项目 -> 仅生成lib_json
6. 再次右击lib_json,选择 -> 仅用于项目 -> 仅链接lib_json
7. 生成的.lib文件夹在.\makefiles\msvc2010中
最终生成windows下的.lib静态链接库文件
0x2: 简单示例
1. 在jsonCPP源代码文件夹中创建文件夹include、lib
2. 在include中创建文件夹json,将jsoncpp-src -> include -> json 中的.h文件全部复制过来
3. 在lib中创建文件夹debug和release,把上一步编译生成的.lib文件复制过来
//新建一个windows console控制台项目
4. 选择项目 -> 属性
5. 选择配置属性 -> C/C++ -> 常规,右边的"附加包含目录",附加包含目录: D:\study\toolsForVS2010\jsonPP\include
6. 选择配置属性 -> C/C++ -> 代码生成,右边的"运行库",选择MTd
7. 选择配置属性 -> 链接器 -> 常规,右边的"附加库目录",添加lib文件夹(静态链接库)路径
8. 选择配置属性 -> 链接器 -> 输入,右边的"附加依赖项",添加lib文件
9. 点击应用完成json配置
//若项目需要发布时(即项目选择release)
10. 配置属性 -> C/C++ -> 代码生成,右边的"运行库",选择MT
11. 选择配置属性 -> 链接器 -> 常规,右边的"附加库目录",添加lib文件夹
12. 然后可以运行程序获得release版本程序
main.cpp
// AliHealthExamination.cpp : 定义控制台应用程序的入口点。
//
#include <fstream>
#include <iostream>
#include <string>
#include "json/json.h"
using namespace std;
#pragma comment(lib,"lib_json")
void main()
{
ifstream ifs;
ifs.open("test.json", ios::out|ios::in);
if(!ifs.is_open())
{
cout<<"fail to open file."<<endl;
return;
}
Json::Reader reader;
Json::Value root;
if(!reader.parse(ifs, root))
{
cout<<"fail to parse."<<endl;
return;
}
string s_name;
int i_age;
for(int i=0; i<root.size(); ++i)
{
s_name = root[i]["name"].asString();
i_age = root[i]["age"].asInt();
cout<<"name:"<<s_name.c_str()<<", "<<"age:"<<i_age<<endl;
}
}
json文件与生成结果
1. json文件:[{"name":"kanguolai","age":25},{"name":"kanguoqu","age":18}]
2. 生成结果
Copyright (c) 2015 LittleHann All rights reserved