1.安装jansson
1
2
3
|
./configure make make
install |
2.生成帮助文档
1
2
|
cd
doc make
html |
编译安装doc时提示 spinx-build not a command
执行下面语句安装sphinx
1
|
easy_install
-U Sphinx |
生成_build文件夹
1
|
cd
_build/html/ |
使用火狐浏览器启动帮助文档
1
|
Firefox
index.html |
3.编程
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
|
包含头文件:
#include <jansson.h> 编译连接时加库
-ljansson gcc
–o source source.c –ljansson 如果执行程序出现:error while loading
shared libraries: libjansson.so.4: cannot open shared object file: No such file or directory 找不到libjansson.so.4这个库时用下面方法解决 //查找libjansson.so.4所在位置 Whereis
libjansson 显示:libjansson:
/usr/local/lib/libjansson.a /usr/local/lib/libjansson.la /usr/local/lib/libjansson.so 自己的libjansson.so所在位置为:/usr/local/lib/libjansson.so //确定libjansson.so是否真的存在 cd
/usr/local/lib //如果存在,执行下面语句,创建一个libjansson.so的符号链接到/usr/lib目录下 ln
-s /usr/local/lib/libjansson.so /usr/lib/libjansson.so.4 //重新加载库 ldconfig json_t
*json_string( const char *value) 返回一个json
string的数据类型,转换成这个库可以识别的格式。错误返回NULL,必须是UTF-8格式的。
Return value: New reference.
Returns a new JSON
string, or NULL on error. value must be a valid UTF-8 encoded Unicode string. json_t
*json_string_nocheck( const char *value) 与json_string()相同,不检查value的有效性
Return value: New reference.
Like json_string(), but doesn’t check that value is valid UTF-8. Use this function
only if you
are certain that this really
is the case (e.g.
you have already checked it by other means). const char *json_string_value( const json_t
*string) 返回json
string中的字符串,是c语言的字符串。
Returns the associated value of string as a null terminated UTF-8 encoded string, or
NULL if string
is not a JSON string.
The retuned value is read-only and must not be modified or freed by the user. It is valid as long as
string exists, i.e. as long as
its reference count has not dropped to zero. int json_string_set( const json_t
*string, const char *value) 设置string对应的值,如果value是无效的UTF-8值,设置失败。
Sets the associated value of string to value. value must be a valid UTF-8 encoded Unicode string. Returns 0 on success and -1 on error. int json_string_set_nocheck( const json_t
*string, const char *value) 与json_string_set()相同,只是不检查value是否是有效的UTF-8类型 Like
json_string_set(), but doesn’t check that value is valid UTF-8. Use this function
only if you
are certain that this really
is the case (e.g.
you have already checked it by other means). |
我主要是使用字符串的形式,参考的jansson-2.6/test/suites/api/test_object.c代码
下面的程序功能是:输出一个json格式的字符串,gcc 的时候别忘了加 -ljansson
需要特别注意的地方时jansson数组的处理,在需要循环的加入数组的时候需要json_deep_copy()函数的帮助。如下例子:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
|
json_t
copy; json_t
object; json_t
array; json_object_set_new
(object, "test" ,
json_string( "testvalue1" )); copy
= json_deep_copy(object); json_array_append(arr,
copy); json_object_set_new
(object, "test" ,
json_string( "testvalue2" )); copy
= json_deep_copy(object); json_array_append(arr,
copy); |
//下面的是处理字符串
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
|
#include
<stdio.h> #include
<jansson.h> int event_jansson() { json_t
*objectmsg; char *result; objectmsg
= json_object(); json_object_set_new
(objectmsg, "inc" ,
json_string( "value-incID" )); json_object_set_new
(objectmsg, "src" ,
json_string( "a" )); json_object_set_new
(objectmsg, "des" ,
json_string( "b" )); json_object_set_new
(objectmsg, "protocol" ,
json_string( "c" )); json_object_set_new
(objectmsg, "policy" ,
json_string( "d" )); json_object_set_new
(objectmsg, "snapshot" ,
json_string( "e" )); json_object_set_new
(objectmsg, "name" ,
json_string( "f" )); json_object_set_new
(objectmsg, "Type" ,
json_string( "g" )); json_object_set_new
(objectmsg, "Path" ,
json_string( "h" )); json_object_set_new
(objectmsg, "domain" ,
json_string( "i" )); result
= json_dumps(objectmsg, JSON_PRESERVE_ORDER); printf ( "result=%s\n" ,result); free (result); json_decref(objectmsg); return 0; } int main() { event_jansson(); return 0; } |
下面的程序是从一个jason文件中取出内容。
tmp.json文件中的内容是:
{"name1": "value1", "name2": "value2", "name3": "value3", "name4": "value4"}
vim test.c
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
|
#include
<string.h> #include
<stdio.h> #include
<jansson.h> /*
关键字个数 */ #define
COUNTMAX 256 /*
关键字长度 */ #define
LENMAX 256 struct policymsg { int size; char keyword[COUNTMAX][LENMAX]; char keycount[COUNTMAX][LENMAX]; }; /*
判断janson的类型 */ int my_json_type(json_t
*value) { if (json_is_object(value)) { printf ( "json_is_object\n" ); return JSON_OBJECT; } if (json_is_array(value)) { printf ( "json_is_array\n" ); return JSON_ARRAY; } if (json_is_string(value)) { printf ( "json_is_string\n" ); return JSON_STRING; } if (json_is_integer(value)) { printf ( "json_is_integer\n" ); return JSON_INTEGER; } if (json_is_real(value)) { printf ( "json_is_real\n" ); return JSON_REAL; } if (json_is_number(value)) { printf ( "json_is_number\n" ); } if (json_is_boolean(value)) { printf ( "json_is_boolean\n" ); } if (json_is_null(value)) { printf ( "json_is_null\n" ); return JSON_NULL; } if (json_is_true(value)) { printf ( "json_boolean(1)\n" ); return JSON_TRUE; } if (json_is_false(value)) { printf ( "json_boolean(0)\n" ); return JSON_FALSE; } } struct policymsg
get_policy_json( char *jsonfile) { struct policymsg
policyinfo; int i,
size; void *iter; json_t
*object; json_t
*iter_values; json_error_t
error; object
= json_object(); object
= json_load_file (jsonfile, 0, &error); policyinfo.size
= json_object_size (object); #if
0 //size
= json_object_size (object); //printf("size=%d\n",
size); /*
取出object中的值 */ //struct
policy iter_get_value(json_t *object) char *result; result
= json_dumps(object, JSON_PRESERVE_ORDER); printf ( "result=%s\n" ,
result); /*
判断读取的jansson类型 */ printf ( "判断是什么类型\n" ); my_json_type(object); printf ( "result_size
= %d\n" , strlen (result)); #endif iter
= json_object_iter(object); i
= 0; while (1) { strcpy (policyinfo.keyword[i],
json_object_iter_key(iter)); iter_values
= json_object_iter_value(iter); strcpy (policyinfo.keycount[i],json_string_value(iter_values)); //printf("values[%d]=%s\n",
i,json_string_value(iter_values[i])); if ((iter
= json_object_iter_next(object, iter)) == NULL) { //printf("iterate
end\n"); break ; } i++; } #if
0 iter
= json_object_iter_at(object, "b" ); if (iter) { iter_keys[i]
= json_object_iter_key(iter); iter_values[i]
= json_object_iter_value(iter); printf ( "values[%d]=%s\n" ,
i,json_string_value(iter_values[i])); } #endif json_decref(object); return policyinfo; } #if
1 int main() { //result
= "{\"objectmsg\": \"{\"name1\": \"value1\", \"name2\": \"value2\", \"name3\": \"value3\", \"name4\": \"value4\"}\", \"name5\": \"value6\"}"; //{"name1":
"value1", "name2": "value2", "name3": "value3", "name4": "value4"} char *str
= "./tmp.json" ; struct policymsg
policyinfo; policyinfo
= get_policy_json(str); int i
= 0; while (
i < policyinfo.size) { printf ( "keyword
= %s\n" ,
policyinfo.keyword[i]); printf ( "value
= %s\n" ,
policyinfo.keycount[i]); i++; } } #endif |
编译:
gcc test.c -ljansson