最新在做乐橙SDK的时候,发现有部分需要跟服务进行交互,原先支持乐橙的协议已经写好了。目前想将平台的协议采用透传接口,逐步将原有的协议过渡到透传协议,外面只要传递相应的json格式的数据,在内部进行解析,也就是做好序列化和反序列化。其中将会涉及到json的解析,在这里写一个笔记作为以后的参考。
1.重要函数说明
【1】两个创建
【创建JSON对象】cJSON *cJSON_CreateObject(void);
【创建JSON数组】cJSON *cJSON_CreateArray(void);

【2】两种添加
【向对象中添加】voidcJSON_AddItemToObject(cJSON *object,const char *string,cJSON *item);
【向数组中添加】void cJSON_AddItemToArray(cJSON *array, cJSON *item);

【3】常用几招
【向对象中增加数字】cJSON_AddItemToObject(root, "value", cJSON_CreateNumber(value));
【向对象中增加文件】cJSON_AddItemToObject(root, "string", cJSON_CreateString(string));

【4】JSON嵌套
【向对象中增加数组】cJSON_AddItemToObject(root, "rows", rows = cJSON_CreateArray());
【向数组中增加对象】cJSON_AddItemToArray(rows, row = cJSON_CreateObject());

2.创建各种各样的JSON数据包
在这里通过代码举几个例子,更多的内容请查看代码仓库中的相关文件。
【1】JSON数字

//注意要在前面定义变量,这不是C++代码,C++可以在中间定义变量。
void create_single_number(void) {
    cJSON *root;
    char *out;
    int value = 24;

    root = cJSON_CreateObject(); // 创建根

    cJSON_AddItemToObject(root, "value", cJSON_CreateNumber(value));

    // 打印并释放
    out = cJSON_Print(root); cJSON_Delete(root); printf("%s\n",out); free(out);

    // 控制台输出
#if 0
    {
        "value": 24
    }
#endif
}

简单说明】
【1】cJSON_AddItemToObject(root, “value”, cJSON_CreateNumber(value));
【2】cJSON_AddNumberToObject(root, “value”, value);
【1】和【2】效果完全相同。

【2】JSON字符串

void create_single_string(void) {
    cJSON *root;
    char *out;
    char *name = "xukai871105";

    root = cJSON_CreateObject(); // 创建根
    // 方法 使用cJSON_AddItemToObject,推荐使用
    cJSON_AddItemToObject(root, "name", cJSON_CreateString(name));

    // 打印并释放
    out = cJSON_Print(root); cJSON_Delete(root); printf("%s\n",out); free(out);

    // 控制台输出
#if 0
    {
        "name": "xukai871105"
    }
#endif
}

【简单说明】
【1】 cJSON_AddItemToObject(root, “name”, cJSON_CreateString(name));
【2】 cJSON_AddStringToObject(root, “name”,name);
【1】和【2】效果完全相同。

【3】JSON布尔类型
void create_bool(void) {
    cJSON *root;
    char *out;

    root = cJSON_CreateObject(); // 创建根

    cJSON_AddItemToObject(root, "success", cJSON_CreateFalse());

    // 打印并释放
    out = cJSON_Print(root); cJSON_Delete(root); printf("%s\n",out); free(out);

    // 控制台输出
#if 0
    {
        "success": false
    }
#endif
}

【简单说明】
【1】布尔类型不需要加引号。

3.JSON格式嵌套
JSON格式在使用时往往存在嵌套,例如JSON对象中嵌套JSON数组而JSON数组中嵌套JSON对象,下面就通过几个简单的例子说明问题。
【1】JSON简单嵌套

void create_simple(void) {
    cJSON *root;
    char *out;
    int list[4] = {5,6,7,8};

    root = cJSON_CreateObject(); // 创建根
    cJSON_AddItemToObject(root, "lists", cJSON_CreateIntArray(list, 4));

    // 打印并释放
    out = cJSON_Print(root); cJSON_Delete(root); printf("%s\n",out); free(out);

    // 控制台输出
#if 0
    {
        "lists": [5, 6, 7, 8]
    }
#endif
}

【2】JSON复杂嵌套

void create_complex(void) {
cJSON *root, *rows, *row;
char *out;
int i = 0;

char *title[3] = { "树莓派学习笔记——索引博文",
"树莓派学习笔记——GPIO功能学习",
"物联网学习笔记——索引博文"};
char *url[3] = { "http://blog.csdn.net/xukai871105/article/details/23115627",
"http://blog.csdn.net/xukai871105/article/details/12684617",
"http://blog.csdn.net/xukai871105/article/details/23366187"};

root = cJSON_CreateObject(); // 创建根
cJSON_AddNumberToObject(root, "total", 3);

// 在object中加入array
cJSON_AddItemToObject(root, "rows", rows = cJSON_CreateArray());

for(i = 0; i < 3; i++) {
// 在array中加入object
cJSON_AddItemToArray(rows, row = cJSON_CreateObject());
cJSON_AddItemToObject(row, "title", cJSON_CreateString(title[i]));
cJSON_AddItemToObject(row, "url", cJSON_CreateString(url[i]));
}

// 打印并释放
out = cJSON_Print(root); cJSON_Delete(root); printf("%s\n",out); free(out);

// 控制台输出
#if 0
{
"total": 3,
"rows": [{
"title": "树莓派学习笔记——索引博文",
"url": "http://blog.csdn.net/xukai871105/article/details/23115627"
}, {
"title": "树莓派学习笔记——GPIO功能学习",
"url": "http://blog.csdn.net/xukai871105/article/details/12684617"
}, {
"title": "物联网学习笔记——索引博文",
"url": "http://blog.csdn.net/xukai871105/article/details/23366187"
}]
}
#endif
}

【简单说明】
rows为JSON对象,rows对象中嵌套JSON数组,每一个JSON数组的元素又是一个JSON对象,该该对象名为row,row对象中具有两个键值对,分别是titile和url。

GitHub 加速计划 / cj / cJSON
10.45 K
3.16 K
下载
Ultralightweight JSON parser in ANSI C
最近提交(Master分支:2 个月前 )
424ce4ce This reverts commit 5b502cdbfb21fbe5f6cf9ffbd2b96e4281a741e6. Related to #860 4 个月前
32497300 - 5 个月前
Logo

旨在为数千万中国开发者提供一个无缝且高效的云端环境,以支持学习、使用和贡献开源项目。

更多推荐