`
hulianwang2014
  • 浏览: 690133 次
文章分类
社区版块
存档分类
最新评论
  • bcworld: 排版成这样,一点看的欲望都没有了
    jfinal

cJSON学习笔记

 
阅读更多

1.JSON格式简述

JSON(JavaScript Object Notation) 是一种轻量级的数据交换格式。易于人阅读和编写,同时也易于机器解析和生成。它基于JavaScript(Standard ECMA-262 3rd Edition - December 1999)的一个子集。 JSON采用完全独立于语言的文本格式,但是也使用了类似于C语言家族的习惯(包括C, C++, C#, Java, JavaScript, Perl, Python等)。这些特性使JSON成为理想的数据交换语言。(来自“开源中国”资料)
cJSON是一个超轻巧,携带方便,单文件,简单的可以作为ANSI-C标准的JSON解析器。
接触yeelink平台之后,慢慢接触到JSON格式,虽然一些简单的情况可以通过string库函数解析和组装JSON数据包,但是若有cJSON库的帮助,解析和组装JSON数据包的工作便会变得简单的多,下面就从两个例子出发说明cJSON数据包的使用方法。

2.JSON结构体

熟悉使用cJSON库函数可从cJSON结构体入手,cJSON结构体如下所示:
typedef struct cJSON {
 struct cJSON *next,*prev; 
 struct cJSON *child; 
 int type; 
 char *valuestring; 
 int valueint;
 double valuedouble; 
 char *string; 
} cJSON;

几点说明

1.cJOSN结构体为一个双向列表,并可通过child指针访问下一层。
2.type变量决定数据项类型(键的类型),数据项可以是字符串可以是整形,也可以是浮点型。如果是整形值的话可从valueint,如果是浮点型的话可从valuedouble取出,以此类推。
3.string可理解为节点的名称,综合此处的第2点可理解为“键”的名称。

3.解析JSON数据包

例如在yeelink平台中读取一个开关量的结果,向yeelink平台请求之后可以获得以下JSON数据包:
{"timestamp":"2013-11-19T08:50:11","value":1}
在这个JSON数据包中有两个数据项(键值对),一个是时间戳,该时间戳为字符串形式;另一个是开关值,该开关值为整型。该例子主要用于模拟向yeelink平台请求开关量数据。

参考代码

#include <stdio.h>
#include <stdlib.h>
#include "cJSON.h"
// 被解析的JSON数据包
char text[] = "{\"timestamp\":\"2013-11-19T08:50:11\",\"value\":1}";
int main (int argc, const char * argv[])
{
    cJSON *json , *json_value , *json_timestamp;
    // 解析数据包
    json = cJSON_Parse(text);
    if (!json)
    {
        printf("Error before: [%s]\n",cJSON_GetErrorPtr());
    }
    else
    {
        // 解析开关值
        json_value = cJSON_GetObjectItem( json , "value");
        if( json_value->type == cJSON_Number )
        {
            // 从valueint中获得结果
            printf("value:%d\r\n",json_value->valueint);
        }
        // 解析时间戳
        json_timestamp = cJSON_GetObjectItem( json , "timestamp");
        if( json_timestamp->type == cJSON_String )
        {
            // valuestring中获得结果
            printf("%s\r\n",json_timestamp->valuestring);
        }
        // 释放内存空间
        cJSON_Delete(json);
    }
    return 0;
}

运行结果

value:1
2013-11-19T08:50:11

若干说明

1.cJSON_Parse函数负责解析JSON数据包,并按照cJSON结构体的结构序列化整个数据包。使用该函数会通过malloc函数在内存中开辟一个空间,使用完成需要手动释放。
2.cJSON_GetObjectItem函数可从cJSON结构体中查找某个子节点名称(键名称),如果查找成功可把该子节点序列化到cJSON结构体中。
3.如果需要使用cJSON结构体中的内容,可通过cJSON结构体中的valueint和valuestring取出有价值的内容(即键的值)
4.可通过cJSON_Delete释放内存空间。

4.组装JSON数据包

组装数据包的过程和解析数据包的过程相反,下面的例子描述如何组装以下数据包,该数据包只有一个数据项(键值对)。该例子主要用于模拟向yeelink平台上传传感器数据。
{
"value": 123.400000
}

参考代码

#include <stdio.h>
#include <stdlib.h>
#include "cJSON.h"
int main (int argc, const char * argv[])
{
    // 创建JSON Object
    cJSON *root = cJSON_CreateObject();
    // 加入节点(键值对),节点名称为value,节点值为123.4
    cJSON_AddNumberToObject(root,"value",123.4);
    // 打印JSON数据包
    char *out = cJSON_Print(root);
    printf("%s\n",out);
    // 释放内存
    cJSON_Delete(root);
    free(out);
    return 0;
}

若干说明

1.cJSON_CreateObject函数可创建一个根数据项,之后便可向该根数据项中添加string或int等内容
2. cJSON_AddNumberToObject向节点中添加子节点,例如此处添加value节点,节点值为123.4
3. cJSON_Print函数可以打印根数据项,加入制表符换行符等标识符使得JSON数据包更易阅读
4. 使用free函数释放被out占用的内存空间

5.总结

整体来说cJSON简单易用,解决了JSON数据包解析和组装的问题,向着心中的目标更近一步了。

6.参考资料

分享到:
评论

相关推荐

    CJSON学习笔记.xlsx

    最近有个用单片机的项目用到了CJSON,本文总结了CJSON应用的主要API函数及应用的注意事项

    STM32学习笔记之Cjson的使用

    1、解析JSONJ结构得到cjson对象:cJSON * root=cJSON_Parse(char *buf); 2、获取无格式的json对象:cJSON_PrintUnformatted(cJSON *item) 3、根据键值获取对应的值:cJSON *cJSON_GetObjectItem(cJSON *object,const...

    cJSON学习源码.zip

    cjson官方源码,无改动,适合C语言学习者的入门开源项目,欢迎大家随意下载,程序编写条理清晰,简单易懂,主要对cjson.h和cjson.c文件进行阅读与研究即可。

    cJSON学习总结(含VS2010的实例工程)

    cJSON学习总结,含多个VS2010的实例工程

    loadrunner11.0+cJson中用到的cJson.dll及cJson.h

    loadrunner11.0+cJson处理json的办法,在网上查询到很多这个介绍,但是怎么也找不到cJson.dll ,于是花了不少时间自己编译了一个cJson.dll。 1、将编译出来的cjson.dll,cjson.h放到loadrunner脚本的根目录下,然后在...

    cJSON的源代码

    cJSON源码

    cJSON函数库 cJson.c cjson.h

    cJSON函数库 json解析库 cjson.c 和cjson.c添加一起编译

    单片机cJSON.rar_STM32 CJSON_cjson_cjson stm32_cjson库_stm32 cjson

    适用于单片机的cjson库,使用内存比价小,可以用于stm32单片机

    CJSON_cjson_

    CJSON,可直接使用,适用于c语言使用JSON

    cJSON_cjson_

    简单易懂,功能接口齐全的cJSON,适用于单片机嵌入式开发

    Cjson移植STM32方法

    Cjson移植STM32方法

    cJSON源代码,包含cJSON.c和cJSON.h 共2个文件 h:1个 c:1个

    #define cJSON_False 0 #define cJSON_True 1 #define cJSON_NULL 2 #define cJSON_Number 3 #define cJSON_String 4 #define cJSON_Array 5 #define cJSON_Object 6 #define cJSON_IsReference 256 #define cJSON...

    cjson库,包含各种cjson的函数

    cjson的.c和.h文件,里面包含cjson的解析函数等等

    优化版cJson解析库

    cJSON官方库无法解析long long int 类型值,本库是在cJSON官方库上进行修改优化,最终能完美的解析long long int 类型数据,纯C语言编写,便于移植到各个平台。

    Lua cjson库在windows版本cjson.dll

    找了老半天都没有windows版本的cjson.dll库,只能手动编译。 下载:http://www.kyne.com.au/~mark/software/lua-cjson.php 转换为vs2005工程后编译出错,把所有static inline的函数修改为static的,把一些不...

    cjson.c和cjson.h文件

    json在C语言中用到的.c和.h文件(cjson) 由于c语言中,没有直接的字典,字符串数组等数据结构,所以要借助结构体定义,处理json。如果有对应的数据结构就方便一些, 如python中用json.loads(json)就把json字符串...

    cJSON库可以更改数字精度

    简单的cjson库,我更改过cjson.c的print_number函数,最大数字精度可以自己改,不会出现跟一串0,想改的话改这一句sprintf(str,"%.9lf",d);

    开源的cjson.c和cjson.h

    开源的cjson.c和cjson.h,用于在C语言平台上实现JSON的数据传递。

    Cjson 动态链接库

    cjson解析 示例代码: memberlist = getValue(lr_eval_string("{response}"),"\"memberList\":",",\"totalCount\"",200,1); root = (cJSON *) cJSON_Parse(memberlist); arraysize = cJSON_GetArraySize(root);...

Global site tag (gtag.js) - Google Analytics