rapidjson组装map和数组array的代码示例

直接上码:

#include <iostream>
#include <map>

// 请自己下载开源的rapidjson
#include "rapidjson/prettywriter.h"
#include "rapidjson/rapidjson.h"
#include "rapidjson/document.h"
#include "rapidjson/stringbuffer.h"
#include "rapidjson/writer.h"
#include "rapidjson/memorystream.h"
#include <sys/types.h>
#include <vector>

using namespace std;
using rapidjson::Document;
using rapidjson::StringBuffer;
using rapidjson::Writer;
using namespace rapidjson;


// 注意int和uint64_t
map<string,uint64_t> g_mChildInt;
map<string,string> g_mChildString;
string formJson(const map<string,int> &mInt,const map<string,string> &mString,const string &strChild="",uint64_t> &mChildInt=g_mChildInt,string> &mChildString=g_mChildString,const string &strChild2="",uint64_t> &mChildInt2=g_mChildInt,string> &mChildString2=g_mChildString)
{
	Document document;

    Document::AllocatorType& allocator = document.GetAllocator(); 
    Value root(kObjectType);

    Value key(kStringType);  
    Value value(kStringType); 

	// 当前级别
	for(map<string,int>::const_iterator it = mInt.begin(); it != mInt.end(); ++it) 
	{
		key.SetString(it->first.c_str(),allocator);  
    	root.AddMember(key,it->second,allocator);
	}

	for(map<string,string>::const_iterator it = mString.begin(); it != mString.end(); ++it)
	{
		key.SetString(it->first.c_str(),allocator);  
   		value.SetString(it->second.c_str(),value,allocator);
	}

	// 孩子级别
	if(!strChild.empty())
	{
		Value child(kObjectType);
		for(map<string,uint64_t>::const_iterator it = mChildInt.begin(); it != mChildInt.end(); ++it) 
		{
			key.SetString(it->first.c_str(),allocator);  
	    	child.AddMember(key,allocator);
		}

		for(map<string,string>::const_iterator it = mChildString.begin(); it != mChildString.end(); ++it)
		{
			key.SetString(it->first.c_str(),allocator);  
	   		value.SetString(it->second.c_str(),allocator);
		}

		key.SetString(strChild.c_str(),allocator); 
		root.AddMember(key,child,allocator);
	}

	// 孩子级别
	if(!strChild2.empty())
	{
		Value child(kObjectType);
		for(map<string,uint64_t>::const_iterator it = mChildInt2.begin(); it != mChildInt2.end(); ++it) 
		{
			key.SetString(it->first.c_str(),string>::const_iterator it = mChildString2.begin(); it != mChildString2.end(); ++it)
		{
			key.SetString(it->first.c_str(),allocator);
		}

		key.SetString(strChild2.c_str(),allocator);
	}

    StringBuffer buffer;  
    Writer<StringBuffer> writer(buffer);  
    root.Accept(writer);  
    return buffer.GetString();  

}


string formJsonWithArray(const map<string,const string &strChild1,uint64_t> &mChildInt,string> &mChildString,string &strChild2,vector<map<string,uint64_t> >&mVecChildInt,string> >&mVecChildString)
		        
{
	Document document;
	
    Document::AllocatorType& allocator = document.GetAllocator(); 
    Value root(kObjectType);

    Value key(kStringType);  
    Value value(kStringType); 

	// 当前级别
	for(map<string,allocator);
	}

	// 孩子级别
	if(!strChild1.empty())
	{
		Value child(kObjectType);
		for(map<string,allocator);
		}

		key.SetString(strChild1.c_str(),allocator);
	}

	// 孩子级别
	unsigned int uiSize1 = mVecChildInt.size();
	unsigned int uiSize2 = mVecChildString.size();
	if(!strChild2.empty() && uiSize1 == uiSize2)
	{
		Value array(rapidjson::kArrayType);  
		for(unsigned int i = 0; i < uiSize1; ++i)
		{
			Value child(kObjectType);
			for(map<string,uint64_t>::iterator it = mVecChildInt[i].begin(); it != mVecChildInt[i].end(); ++it) 
			{
				key.SetString(it->first.c_str(),allocator);  
		    	child.AddMember(key,allocator);
	
			}
		
			for(map<string,string>::iterator it = mVecChildString[i].begin(); it != mVecChildString[i].end(); ++it)
			{
				key.SetString(it->first.c_str(),allocator);  
		   		value.SetString(it->second.c_str(),allocator);
			}

			array.PushBack(child,allocator);  

		}

		key.SetString(strChild2.c_str(),array,allocator);

	}

    StringBuffer buffer;  
    Writer<StringBuffer> writer(buffer);  
    root.Accept(writer);  
    return buffer.GetString();  
}


void test1()
{
	map<string,int> mInt;
	map<string,string> mString;
	mInt["code"] = 0;
	mString["msg"] = "ok";

	string strChild1 = "xxx";
	map<string,uint64_t> mChildInt1;
	map<string,string> mChildString1;
	mChildInt1["key"] = 729;
	mChildString1["kk"] = "vv";

	string strChild2 = "yyy";
	map<string,uint64_t> mChildInt2;
	map<string,string> mChildString2;
	mChildInt2["key"] = 730;
	mChildString2["kkk"] = "vvv";

	string s = formJson(mInt,mString,strChild1,mChildInt1,mChildString1,strChild2,mChildInt2,mChildString2);
	cout << s << endl;
}


void test2()
{
	map<string,uint64_t> mChildInt;
	map<string,string> mChildString;
	mChildString["kk"] = "vv";
	mChildInt["key"] = 729;


	string strChild2 = "data";
	vector<map<string,uint64_t> >mVecChildInt; 
	vector<map<string,string> >mVecChildString;

	{

		map<string,uint64_t> mChildInt; 
		map<string,string> mChildString;

		mChildInt["id"] = 1;
		mChildString["path"] = "pa";
		mChildString["sha"] = "sh";
			
		mVecChildInt.push_back(mChildInt);
		mVecChildString.push_back(mChildString);
	}

	{

		map<string,string> mChildString;

		mChildInt["id"] = 2;
		mChildString["path"] = "pa";
		mChildString["sha"] = "sh";
			
		mVecChildInt.push_back(mChildInt);
		mVecChildString.push_back(mChildString);
	}

	string s = formJsonWithArray(mInt,mChildInt,mChildString,mVecChildInt,mVecChildString);
	cout << s << endl;
}


int main(int argc,char *argv[])
{
	test1();
	test2();

	return 0;
}
结果:

{"code":0,"msg":"ok","xxx":{"key":729,"kk":"vv"},"yyy":{"key":730,"kkk":"vvv"}}
{"code":0,"data":[{"id":1,"path":"pa","sha":"sh"},{"id":2,"sha":"sh"}]}


不多说, 睡觉。

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐


AJAX是一种基于JavaScript和XML的技术,能够使网页实现异步交互,节省带宽和时间,提高用户体验。在使用AJAX时,需要通过解析JSON格式的数据,来获取所需要的数据。
在网页开发中,我们常常需要通过Ajax从后端获取数据并在页面中展示出来。其中,JSON是一种常用的数据格式。那么,在使用Ajax获取JSON数据后,如何将数据取出来呢?
在前端开发中,经常需要循环JSON对象数组进行数据操作。使用AJAX技术可以在不刷新页面的情况下异步获取数据。那么我们该如何循环JSON对象数组呢?下面我们通过一段代码来进行讲解。
AJAX(Asynchronous JavaScript and XML)是一种用于创建 Web 应用程序的技术,它使用 JavaScript 和 XML(或 JSON)来在后台异步传输数据。
AJAX技术被广泛应用于现代Web开发,它可以在无需重新加载页面的情况下,向服务器发出请求并更新页面,实现了异步更新的效果。而传递JSON数据是AJAX中比较常见的一种方法,下面是如何使用AJAX传递JSON数据的详细介绍。
Ajax是一种通过JavaScript和HTTP请求交互的技术,可以实现无需刷新页面的异步数据交互。在处理数据时,常常需要删除一些已存在的数据。本文将介绍如何使用Ajax删除JSON数据库中的数据。
在使用Ajax时,我们经常需要将数据格式化为JSON格式。JSON是一种轻量级数据交换格式,它以键值对的形式来表达数据。
AJAX是一种支持异步请求的技术,它可以让前端页面不用刷新就能向后台请求数据,并异步地展示给用户,提高了用户的体验感。其中,使用JSON格式化数据可以帮助我们更方便快捷地处理返回的数据。
AJAX是一种前端技术,可以通过异步请求来获取数据,并在页面上更新它们。JSON是一种轻量级的数据交换格式,因为它易于读取和编写,因此在Web应用程序中被广泛使用。AJAX传送JSON数据是一种常见的技术,可以让Web应用
在前端开发中,ajax是很常见的技术,它可以在不刷新整个页面的情况下请求服务器数据和更新部分页面。而当需要遍历多个json文件时,可以使用ajax循环遍历来实现。
AJAX技术是实现Web页面无刷新的最佳方式。其中json解析是一种常用的技术,它可以通过AJAX异步请求数据,再用json解析器将返回的json字符串解析成JavaScript对象。下面就让我们来看看如何使用ajax解析json数据。
AJAX技术可以在不刷新整个WEB页面的情况下与服务器进行数据交换,这使得在现代WEB应用中使用AJAX技术变得非常普遍。而访问JSON数组是一种非常常见的AJAX操作。在本文中,我们将向您展示如何使用AJAX技术循环遍历JSO
Ajax(Asynchronous JavaScript and XML)是一种在不重新加载整个页面的情况下更新网页的技术。它可以向服务器发送请求并接收响应,然后使用JavaScript动态地显示内容。
AJAX技术可以帮助我们实现对JSON数据库的循环读取。下面我们来介绍一下如何使用AJAX技术读取JSON数据库。
AJAX是一种在Web应用中实现局部更新的技术。而JSON是一种数据格式,非常适合用来表示数据。在AJAX中,我们经常需要从后端服务器获取JSON格式的数据,在前端页面中进行处理。那么,如何解析JSON数据呢?
AJAX是一种在不重新载入整个页面的情况下,能够更新部分页面的技术,它可以通过异步通信获取后台数据,其中JSON作为一种轻量级数据交换格式,常常被用来传递数据。在使用AJAX接收到后台传送的JSON数据后,需要进行解
在网站开发中,为了减少页面的刷新,异步加载技术成为了开发中越来越常见的一种技术,而 AJAX 技术就是一种常见的实现方式。其中,通过循环读取 JSON 数据能够实现页面内容的实时更新。
在前端开发中,经常需要从服务器获取JSON数据来展示在页面上,而循环遍历这些数据就需要使用AJAX以及JavaScript。本文将介绍如何使用AJAX和JavaScript来循环遍历JSON数据。
在前端开发中,我们常常需要通过 Ajax 请求后端接口获取数据并进行展示。而 JSON 数据则是一种常见的数据格式,因此我们需要了解如何通过 Ajax 获取 JSON 数据。
在使用ajax传递数据时,我们通常会遇到传递json数据类型的情况。那么,接下来我们就来仔细了解一下如何使用ajax传递json数据类型。