我希望使用json-c库来转换文档中包含的所有对象:
{
"name": "mathieu",
"password": "def118e47a2f36b73805b01a5fa3f73b506b98166a929802338db6868e28d942",
"salt": "nXvtCQEqx8l1uNheIJLoO8VI7049vgIS",
"email": "mathieu@mail.com"
}
{
"name": "cesar",
"password": "487b36f3e5a3a74ec3bf2bf48cbc49cde249b08977d22394122c9d512d0e94b4",
"salt": "Q3QnWFZnLXg8217V1uLaBka6R3CZvCfl",
"email": "cesar@mail.com"
}为了转换它们(暂时我只想显示),我使用了以下代码(我遵循了这个Youtube视频的说明):
#include <stdio.h>
#include <stdlib.h>
#include <json-c/json.h>
//#include "../../include/personnes.h"
//int parseMyJsonPersonne(){
int main(){
FILE* fichier = NULL;
char buffer[1024];
struct json_object *parsed_json;
struct json_object *name;
struct json_object *password;
struct json_object *salt;
struct json_object *email;
fichier = fopen("../../data/Personne.json", "r");
if (fichier != NULL) {
fread(buffer, 1024, 1, fichier);
}
else {
printf("Une ERREUR est survenue lors du chargement des différents comptes\n");
return 1;
}
fclose(fichier);
printf("buffer : %s\n", buffer);
parsed_json = json_tokener_parse(buffer);
json_object_object_get_ex(parsed_json, "name", &name);
json_object_object_get_ex(parsed_json, "password", &password);
json_object_object_get_ex(parsed_json, "salt", &salt);
json_object_object_get_ex(parsed_json, "email", &email);
printf("name : %s\n", json_object_get_string(name));
printf("password : %s\n", json_object_get_string(password));
printf("salt : %s\n", json_object_get_string(salt));
printf("email : %s\n", json_object_get_string(email));
json_object_object_get_ex(parsed_json, "name", &name);
printf("name 2 : %s\n", json_object_get_string(name));
free(name);
free(password);
free(salt);
free(email);
return 0;
}这就是终端在编译和执行之后向我展示的内容:
buffer : {
"name": "mathieu",
"password": "def118e47a2f36b73805b01a5fa3f73b506b98166a929802338db6868e28d942",
"salt": "nXvtCQEqx8l1uNheIJLoO8VI7049vgIS",
"email": "mathieu@mail.com"
}
{
"name": "cesar",
"password": "487b36f3e5a3a74ec3bf2bf48cbc49cde249b08977d22394122c9d512d0e94b4",
"salt": "Q3QnWFZnLXg8217V1uLaBka6R3CZvCfl",
"email": "cesar@mail.com"
}
name : mathieu
password : def118e47a2f36b73805b01a5fa3f73b506b98166a929802338db6868e28d942
salt : nXvtCQEqx8l1uNheIJLoO8VI7049vgIS
email : mathieu@mail.com
name 2 : mathieu下面是我的各种问题:
发布于 2020-04-09 10:43:40
json_tokener_parse()返回它在提供的缓冲区中找到的第一个JSON对象。调用它时,将其放入一个名为parsed_json的变量中。
由于您第二次尝试获取您一直传递给parsed_json的名称,
json_object_object_get_ex(parsed_json, "name", &name);
printf("name 2 : %s\n", json_object_get_string(name));检索相同的名称。
您需要做的是通过调用json_tokener_parse_ex继续解析。根据文档的说法,它的接口是
JSON_EXPORT struct json_object* json_tokener_parse_ex(
struct json_tokener * tok,
const char * str,
int len
)哪里
参数 tok以前与
json_tokener_new()一起分配的json_tokener str具有任何有效的JSON表达式的字符串。不需要终止null。 len of str的长度
它基本上会像json_tokener_parse()一样解析输入缓冲区,但是在内部使用令牌时,当需要配置更多的东西时,令牌就能够提醒您。这是通过返回json_tokener_continue.来完成的
为了获得更多的信息,请参考文档。我只是在这里引用上面提供的文档链接中显示的示例:
json_object *jobj = NULL;
const char *mystring = NULL;
int stringlen = 0;
enum json_tokener_error jerr;
do
{
mystring = ... // get JSON string, e.g. read from file, etc...
stringlen = strlen(mystring);
jobj = json_tokener_parse_ex(tok, mystring, stringlen);
} while ((jerr = json_tokener_get_error(tok)) == json_tokener_continue);
if (jerr != json_tokener_success)
{
fprintf(stderr, "Error: %s\n", json_tokener_error_desc(jerr));
// Handle errors, as appropriate for your application.
}
if (tok->char_offset < stringlen) // XXX shouldn't access internal fields
{
// Handle extra characters after parsed object as desired.
// e.g. issue an error, parse another object from that point, etc...
}
// Success, use jobj here.另一个解决方案
至于其他问题,我确认,如果JSON对象的数量不断增加,那么第一个或更高版本的缓冲区就会出现问题。处理这一问题可以找到另一种解决办法。
当然,----您可以一个一个地阅读它们,但是在从文件中读取时,您必须执行一些parsering操作。但是,如果您确信的文件结构将始终是您在问题中发布的文件结构,那么您就很幸运:您可以做的是
fopen()文件,就像现在fgets()而不是fread()逐行读取文件。将数据放入buffer中}。如果是,继续buffer正好包含一个对象。像以前一样调用json_tokener_parse(),并打印与json_object_object_get_ex()共享的数据fclose()文件https://stackoverflow.com/questions/61118408
复制相似问题