C++构造和解析Json的使用示例

概述

JSON是一种轻量级的数据交互格式,易于人阅读和编写,同时也易于机器解析和生成,并有效地提升网络传输效率,实际项目中经常用到,相比xml有很多优点,问问度娘,优点一箩筐。

第三方库

json解析选用jsoncpp作为第三方库,jsoncpp使用广泛,c++开发首选。

jsoncpp目前已经托管到了github上,地址:https://github.com/open-source-parsers/jsoncpp

使用

使用c++进行构造json和解析json,选用vs2010作为IDE。工程中使用jsoncpp的源码进行编译,没有使用jsoncpp的库,为方便大家使用把dll和lib库也放到了我的工程jsoncpplib文件夹下,有需要的可以直接引用库。

待解析的json数据格式如下图:

/********************************************************
Copyright (C), 2016-2017,
FileName: main
Author: woniu201
Description:use jsoncpp src , not use dll, but i also provide dll and lib.
********************************************************/
#include "stdio.h"
#include <string>
#include "jsoncpp/json.h"
using namespace std;
/************************************
@ Brief: read file
@ Author: woniu201
@ Return: file data
************************************/
char *getfileAll(char *fname)
{
 FILE *fp;
 char *str;
 char txt[1000];
 int filesize;
 if ((fp=fopen(fname,"r"))==NULL){
 printf("open file %s fail \n",fname);
 return NULL;
 }
 fseek(fp,0,SEEK_END);
 filesize = ftell(fp);
 str=(char *)malloc(filesize);
 str[0]=0;
 rewind(fp);
 while((fgets(txt,1000,fp))!=NULL){
 strcat(str,txt);
 }
 fclose(fp);
 return str;
}
/************************************
@ Brief: write file
@ Author: woniu201
@ Return:
************************************/
int writefileAll(char* fname,const char* data)
{
 FILE *fp;
 if ((fp=fopen(fname, "w")) == NULL)
 {
 printf("open file %s fail \n", fname);
 return 1;
 }
 fprintf(fp, "%s", data);
 fclose(fp);
 return 0;
}
/************************************
@ Brief: parse json data
@ Author: woniu201
@ Return:
************************************/
int parseJSON(const char* jsonstr)
{
 Json::Reader reader;
 Json::Value resp;
 if (!reader.parse(jsonstr, resp, false))
 {
 printf("bad json format!\n");
 return 1;
 }
 int result = resp["Result"].asInt();
 string resultMessage = resp["ResultMessage"].asString();
 printf("Result=%d; ResultMessage=%s\n", result, resultMessage.c_str());
 Json::Value & resultValue = resp["ResultValue"];
 for (int i=0; i<resultValue.size(); i++)
 {
 Json::Value subJson = resultValue[i];
 string cpuRatio = subJson["cpuRatio"].asString();
 string serverIp = subJson["serverIp"].asString();
 string conNum = subJson["conNum"].asString();
 string websocketPort = subJson["websocketPort"].asString();
 string mqttPort = subJson["mqttPort"].asString();
 string ts = subJson["TS"].asString();
 printf("cpuRatio=%s; serverIp=%s; conNum=%s; websocketPort=%s; mqttPort=%s; ts=%s\n",cpuRatio.c_str(), serverIp.c_str(),
  conNum.c_str(), websocketPort.c_str(), mqttPort.c_str(), ts.c_str());
 }
 return 0;
}
/************************************
@ Brief: create json data
@ Author: woniu201
@ Return:
************************************/
int createJSON()
{
 Json::Value req;
 req["Result"] = 1;
 req["ResultMessage"] = "200";
 Json::Value object1;
 object1["cpuRatio"] = "4.04";
 object1["serverIp"] = "42.159.116.104";
 object1["conNum"] = "1";
 object1["websocketPort"] = "0";
 object1["mqttPort"] = "8883";
 object1["TS"] = "1504665880572";
 Json::Value object2;
 object2["cpuRatio"] = "2.04";
 object2["serverIp"] = "42.159.122.251";
 object2["conNum"] = "2";
 object2["websocketPort"] = "0";
 object2["mqttPort"] = "8883";
 object2["TS"] = "1504665896981";
 Json::Value jarray;
 jarray.append(object1);
 jarray.append(object2);
 req["ResultValue"] = jarray;
 Json::FastWriter writer;
 string jsonstr = writer.write(req);
 printf("%s\n", jsonstr.c_str());
 writefileAll("createJson.json", jsonstr.c_str());
 return 0;
}
int main()
{
 char* json = getfileAll("parseJson.json");
 parseJSON(json);
 printf("===============================\n");
 createJSON();
 getchar();
 return 1;
}

总结

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,谢谢大家对我们的支持。如果你想了解更多相关内容请查看下面相关链接

(0)

相关推荐

  • C++关于构造函数可向父类或者本类传参的讲解

    前面我们学习了C++使用初始化列表的方式来初始化字段的方法: https://www.jb51.net/article/153032.htm 这一节的原理和前面的差不多. 在C++的构造函数中,子类继承父类,那么,在创建一个子类成员时,可以同时向父类或者子类的构造函数进行传参,实现方法如下: 写一个例子:mul_argc.c #include <iostream> #include <cstring> using namespace std ; //英雄联盟类 class Hero

  • 浅析C/C++,Java,PHP,JavaScript,Json数组、对象赋值时最后一个元素后面是否可以带逗号

    1 C,C++,Java,PHP都能容忍末尾的逗号 C,C++,Java中对数组赋值时,最后一个元素末尾的逗号可有可无.下面两行代码对这些语言来说是等效的. int a[] = {1,2,3}; /* 正确 */ int a[] = {1,2,3,}; /* 正确 */ PHP这一点也继承了C的特点,下面的两行代码等效. $a = array(1,2,3); /* 正确 */ $a = array(1,2,3,); /* 正确 */ 2 JavaScript视末尾逗号为语法错误! 然而到了Jav

  • C++生成和解析XML文件的讲解

    概述 1.xml 指可扩展标记语言(EXtensible Markup Language) 2.xml 是一种标记语言,类似html 3.xml 的设计宗旨是传输数据,而非显示数据 4.xml 标签没有被预定义.需要自行定义标签 XML与HTML区别 1.xml 不是 html 的替代. 2.xml 和 html 为不同的目的而设计: 3.xml 被设计为传输和存储数据,其焦点是数据的内容. 4.html 被设计用来显示数据,其焦点是数据的外观. 5.html 旨在显示信息,而 xml 旨在传输

  • C++解析Json的方法详解【jsoncpp】

    本文实例讲述了C++解析Json的方法.分享给大家供大家参考,具体如下: JSON(JavaScript Object Notation) 是一种轻量级的数据交换格式,和xml类似,本文主要对VS2008中使用Jsoncpp解析json的方法做一下记录. Jsoncpp是个跨平台的开源库,下载地址:http://sourceforge.net/projects/jsoncpp/,我下载的是v0.5.0,压缩包大约104K. 方法一:使用Jsoncpp生成的lib文件 解压上面下载的Jsoncpp

  • C++使用JsonCpp库操作json格式数据示例

    本文实例讲述了C++使用JsonCpp库操作json格式数据的方法.分享给大家供大家参考,具体如下: 前言 JSON是一个轻量级的数据定义格式,比起XML易学易用,而扩展功能不比XML差多少,用之进行数据交换是一个很好的选择 JSON的全称为:JavaScript Object Notation ,顾名思义,JSON是用于标记javascript对象的,详情参考http://www.json.org/. 本文选择第三方库JsonCpp来解析json,JsonCpp是比较出名的c++解析库,在js

  • C++中构造函数的参数缺省的详解

    C++中构造函数的参数缺省的详解 前言: 构造函数中参数的值既可以通过实参传递,也可以指定为某些默认值,即如果用户不指定实参值,编译系统就使形参取默认值.在构造函数中也可以采用这样的方法来实现初始化. #include <iostream> using namespace std; class A { public : A(int aa=0,int bb=00); //在声明构造函数时指定默认参数 int volume( ); int a; int b; }; int main( ) { A

  • C++函数指针和回调函数使用解析

    函数指针 函数指针是指向函数的指针变量. 通常我们说的指针变量是指向一个整型变.字符型或数组等变量,而函数指针是指向函数. 函数指针可以像一般函数一样,用于调用函数.传递参数. 函数指针变量的声明: typedef int (*fun_ptr)(int,int); // 声明一个指向同样参数.返回值的函数指针变量 实例 以下实例声明了函数指针变量 p,指向函数 max: #include <stdio.h> int max(int x, int y){ return x > y ? x

  • 关于C++复制构造函数的实现讲解

    复制构造函数是一种特殊的构造函数,有一般构造函数的特性.它的功能是用一个已知的对象来初始化一个被创建的同类对象.复制构造函数的参数传递方式必须按引用来进行传递,请看实例: #include <iostream> #include <cstring> using namespace std ; class Student { private : char name[8]; int age ; char sex ; int score ; public : void disp(); /

  • c/c++拷贝构造函数和关键字explicit详解

    关键字explicit 修饰构造方法的关键字,加上了,就告诉编译器,不可以隐式初始化对象:不加就可以隐式初始化对象: 下面的代码是可以正常编译执行的,但是加了关键字explicit,编译就会错我,因为Test t = 100;是隐式初始化对象,但是如果加上强制类型转换后,就不会有错误了. 强制类型转换:Test t = (Test)100; class Test{ public: Test(int d):data(d){//explicit cout << "C:" <

  • 详解C++的JSON静态链接库JsonCpp的使用方法

    JsonCpp部署方法: 在http://sourceforge.net/projects/jsoncpp/中下载最新版本的jsoncpp库源码. 之后将jsoncpp-src-版本号-tar.gz解压出来,打开makefiles中的jsoncpp.sln进行编译,之后build文件夹下的vs71\debug\lib_json中会有一个.lib静态链接库. JsonCpp主要包含三种类型的class:Value Reader Writer. jsoncpp中所有对象.类名都在namespace

随机推荐