cJson 建立與解析
阿新 • • 發佈:2019-02-12
本文用程式碼簡單介紹cjson的使用方法,1)建立json,從json中獲取資料。2)建立json陣列和解析json陣列
1、 建立json,從json中獲取資料
1 #include <stdio.h> 2 #include "cJSON.h" 3 4 char * makeJson() 5 { 6 cJSON * pJsonRoot = NULL; 78 pJsonRoot = cJSON_CreateObject(); 9 if(NULL == pJsonRoot) 10 { 11 //error happend here 12 return NULL; 13 } 14 cJSON_AddStringToObject(pJsonRoot, "hello", "hello world"); 15 cJSON_AddNumberToObject(pJsonRoot, "number", 10010); 16 cJSON_AddBoolToObject(pJsonRoot, "bool", 1); 17 cJSON * pSubJson = NULL; 18 pSubJson = cJSON_CreateObject(); 19 if(NULL == pSubJson) 20 { 21 // create object faild, exit 22 cJSON_Delete(pJsonRoot); 23 return NULL; 24 } 25 cJSON_AddStringToObject(pSubJson, "subjsonobj", "a sub json string"); 26 cJSON_AddItemToObject(pJsonRoot, "subobj", pSubJson); 27 28 char * p = cJSON_Print(pJsonRoot); 29 // else use : 30 // char * p = cJSON_PrintUnformatted(pJsonRoot); 31 if(NULL == p) 32 { 33 //convert json list to string faild, exit 34 //because sub json pSubJson han been add to pJsonRoot, so just delete pJsonRoot, if you also delete pSubJson, it will coredump, and error is : double free 35 cJSON_Delete(pJsonRoot); 36 return NULL; 37 } 38 //free(p); 39 40 cJSON_Delete(pJsonRoot); 41 42 return p; 43 } 44 45 void parseJson(char * pMsg) 46 { 47 if(NULL == pMsg) 48 { 49 return; 50 } 51 cJSON * pJson = cJSON_Parse(pMsg); 52 if(NULL == pJson) 53 { 54 // parse faild, return 55 return ; 56 } 57 58 // get string from json 59 cJSON * pSub = cJSON_GetObjectItem(pJson, "hello"); 60 if(NULL == pSub) 61 { 62 //get object named "hello" faild 63 } 64 printf("obj_1 : %s\n", pSub->valuestring); 65 66 // get number from json 67 pSub = cJSON_GetObjectItem(pJson, "number"); 68 if(NULL == pSub) 69 { 70 //get number from json faild 71 } 72 printf("obj_2 : %d\n", pSub->valueint); 73 74 // get bool from json 75 pSub = cJSON_GetObjectItem(pJson, "bool"); 76 if(NULL == pSub) 77 { 78 // get bool from json faild 79 } 80 printf("obj_3 : %d\n", pSub->valueint); 81 82 // get sub object 83 pSub = cJSON_GetObjectItem(pJson, "subobj"); 84 if(NULL == pSub) 85 { 86 // get sub object faild 87 } 88 cJSON * pSubSub = cJSON_GetObjectItem(pSub, "subjsonobj"); 89 if(NULL == pSubSub) 90 { 91 // get object from subject object faild 92 } 93 printf("sub_obj_1 : %s\n", pSubSub->valuestring); 94 95 cJSON_Delete(pJson); 96 } 97 98 int main() 99 { 100 char * p = makeJson(); 101 if(NULL == p) 102 { 103 return 0; 104 } 105 printf("%s\n", p); 106 parseJson(p); 107 free(p); //千萬不要忘記釋放記憶體呀,cJSON_Print()函式或者cJSON_PrintUnformatted()產生的記憶體,使用free(char *)進行釋放 108 return 0; 109 }
centos下編譯通過,執行結果如下
1 { 2 "hello": "hello world", 3 "number": 10010, 4 "bool": true, 5 "subobj": { 6 "subjsonobj": "a sub json string" 7 } 8 } 9 obj_1 : hello world 10 obj_2 : 10010 11 obj_3 : 1 12 sub_obj_1 : a sub json string
程式碼解釋如下:
CJSON在記憶體中的儲存方式是用連結串列進行儲存的,所以在進行操作的時候,我們可見的部分全部是用指標進行操作的。
第8行新建一個JSON專案。
第14、15、16行分別添加了字串、數字和bool變數。
第18行新建一個JSON專案:pSubJson。
第25行在新建的pSubJson專案上新增字串。
第26行把我們的新專案新增到最初的專案pJsonRoot上。
第28行把CJSON的記憶體的儲存的資料轉換為字串格式。
結果分析:
第1到8行為建立的JSON字串
第9到12行為從JSON解析得到的資料
2、建立json陣列和解析json陣列
1 //建立陣列,陣列值是另一個JSON的item,這裡使用數字作為演示 2 char * makeArray(int iSize) 3 { 4 cJSON * root = cJSON_CreateArray(); 5 if(NULL == root) 6 { 7 printf("create json array faild\n"); 8 return NULL; 9 } 10 int i = 0; 11 12 for(i = 0; i < iSize; i++) 13 { 14 cJSON_AddNumberToObject(root, "hehe", i); 15 } 16 char * out = cJSON_Print(root); 17 cJSON_Delete(root); 18 19 return out; 20 } 21 22 //解析剛剛的CJSON陣列 23 void parseArray(char * pJson) 24 { 25 if(NULL == pJson) 26 { 27 return ; 28 } 29 cJSON * root = NULL; 30 if((root = cJSON_Parse(pJson)) == NULL) 31 { 32 return ; 33 } 34 int iSize = cJSON_GetArraySize(root); 35 for(int iCnt = 0; iCnt < iSize; iCnt++) 36 { 37 cJSON * pSub = cJSON_GetArrayItem(root, iCnt); 38 if(NULL == pSub) 39 { 40 continue; 41 } 42 int iValue = pSub->valueint; 43 printf("value[%2d] : [%d]\n", iCnt, iValue); 44 } 45 cJSON_Delete(root); 46 return; 47 }
輸出結果
1)建立JSON陣列
[0, 1, 2, 3, 4, 5, 6, 7, 8, 9]
2)解析陣列的輸出結果
value[ 0] : [0] value[ 1] : [1] value[ 2] : [2] value[ 3] : [3] value[ 4] : [4] value[ 5] : [5] value[ 6] : [6] value[ 7] : [7] value[ 8] : [8] value[ 9] : [9]