使用C语言的cJSON中给JSON字符串添加转义
在 cJSON 库中,没有直接提供 一个函数来专门给 JSON 字符串添加转义(如将 "
转义为 \"
,\n
转义为 \\n
等)。
但 cJSON 在 序列化(cJSON_Print
或 cJSON_PrintUnformatted
) 时会自动处理转义字符,确保生成的 JSON 字符串是合法的。
如何让 cJSON 处理转义?
1. 使用 cJSON_Print
或 cJSON_PrintUnformatted
当你将一个字符串(如 "Hello \"World\"\n"
)存入 cJSON_String
并使用 cJSON_Print
序列化时,cJSON 会自动添加转义:
#include "cJSON.h"
#include <stdio.h>int main() {cJSON *root = cJSON_CreateObject();cJSON_AddStringToObject(root, "message", "Hello \"World\"\n"); // 字符串包含引号和换行符char *json_str = cJSON_Print(root); // 自动转义printf("%s\n", json_str);cJSON_Delete(root);free(json_str);return 0;
}
输出(自动转义后的合法 JSON):
{"message": "Hello \"World\"\n"
}
关键点:
-
cJSON_Print
和cJSON_PrintUnformatted
在生成 JSON 字符串时,会自动转义:-
"
→\"
-
\
→\\
-
\n
→\\n
-
\t
→\\t
-
其他控制字符也会被转义。
-
2. 手动转义(如果需要单独处理字符串)
如果 不经过 cJSON 序列化,而是想手动处理字符串的转义,可以自己实现一个函数,例如:
#include <string.h>
#include <stdlib.h>char *escape_json_string(const char *input) {const char *p = input;char *output = malloc(strlen(input) * 2 + 1); // 预留足够空间char *q = output;while (*p) {switch (*p) {case '\"': *q++ = '\\'; *q++ = '\"'; break;case '\\': *q++ = '\\'; *q++ = '\\'; break;case '\b': *q++ = '\\'; *q++ = 'b'; break;case '\f': *q++ = '\\'; *q++ = 'f'; break;case '\n': *q++ = '\\'; *q++ = 'n'; break;case '\r': *q++ = '\\'; *q++ = 'r'; break;case '\t': *q++ = '\\'; *q++ = 't'; break;default: *q++ = *p; break;}p++;}*q = '\0';return output;
}int main() {const char *str = "Hello \"World\"\n";char *escaped = escape_json_string(str);printf("Original: %s\n", str);printf("Escaped: %s\n", escaped);free(escaped);return 0;
}
输出:
Original: Hello "World"
Escaped: Hello \"World\"\n
总结
方法 | 适用场景 | 是否推荐 |
---|---|---|
cJSON_Print / cJSON_PrintUnformatted | 自动在 JSON 序列化时转义 | ✅ 推荐 |
手动转义函数 | 单独处理字符串,不经过 cJSON 序列化 | ⚠️ 需要自己管理内存 |
推荐做法:
✅ 直接使用 cJSON_Print
,让 cJSON 在序列化时自动处理转义,避免手动管理转义逻辑。
如果你有特殊需求(如仅转义字符串而不生成完整 JSON),可以自己实现转义函数(参考上面的 escape_json_string
)。