Bug 记录:UE 结构体转 JSON 时 Key 字段大小写异常 (Editor 与打包后表现不一致)

问题描述 :

在使用 FJsonObjectConverter::UStructToJsonObjectString 将带有 UPROPERTY 的结构体(USTRUCT)转换为 JSON 字符串时,生成的 JSON Key 在 UE 编辑器(PIE)下和打包发布(Packaged)后出现大小写不一致的现象。

示例:

结构体中定义了 UPROPERTY() FString id;

  • 编辑器运行结果: {"id": "..."} (正常小写)

  • 打包发布后结果: {"iD": "..."} (出现异常大写 'D')

根本原因 :

此问题由 Unreal Engine 底层的 FName 机制以及运行时加载顺序差异导致,并非 JSON 转换器本身的 Bug。

  1. FName 的大小写不敏感与全局表:

    UE 的反射系统(UHT)使用 FName 来存储结构体中的变量名(Property Name)。FName 为了提高检索效率,是大小写不敏感的,并共用一个全局字符串表(Name Pool)。

    当引擎生命周期中第一次 创建某个特定拼写的 FName 时(例如 "iD"),该字符串连同其当前的大小写格式就会被永久缓存在全局表中。后续所有同名(忽略大小写)的 FName 都会直接复用第一次注册时的大小写格式。

  2. 环境加载顺序差异:

    编辑器模式和打包后的独立运行环境下,引擎模块(Modules)和资源(Assets)的加载顺序完全不同。

    打包后,在我们的结构体加载前,引擎内部的其他模块或第三方插件率先向内存中注册了名为 "iD"FName

  3. 转换器取值逻辑:

    FJsonObjectConverter 在执行序列化时,会调用 Property->GetName() 获取变量名作为 JSON 的 Key。因为全局表已被污染为 "iD",导致导出的 JSON Key 发生改变。诸如 idnametype 等通用极简词汇极易触发此命名冲突。

解决方案:

方案一:放弃反射自动转换,手动组装 JSON(最推荐,安全稳定)

针对对接外部服务器(后端通常对大小写严格敏感)的接口,避免使用 FJsonObjectConverter,改用底层的 FJsonObject 手动序列化,100% 掌控 Key 名:

C++

复制代码
TSharedPtr<FJsonObject> JsonObj = MakeShareable(new FJsonObject);
JsonObj->SetStringField(TEXT("id"), ResData.id); // 强行硬编码小写 "id"

FString JsonString;
TSharedRef<TJsonWriter<>> Writer = TJsonWriterFactory<>::Create(&JsonString);
FJsonSerializer::Serialize(JsonObj.ToSharedRef(), Writer);

方案二:修改变量命名规避冲突

如果前后端接口允许,在定义 UPROPERTY 时避免使用 id 这样过于泛用的词汇,增加特定前缀降低碰撞概率,例如:

C++

复制代码
UPROPERTY()
FString ResId; // 替代 id
总结 :
  • UE 的 FName 机制决定了依赖反射获取的名称无法保证绝对的大小写安全

  • 凡是涉及到跨系统通信(网络协议、保存本地 JSON/XML 配置文件等)且要求严格大小写的场景,永远不要轻信自动反射序列化工具对于通用词汇(id, name, data 等)的处理,手动构建或加特异性前缀才是最稳妥的做法。

相关推荐
mpr0xy10 分钟前
行走编程:把你的 Mac 变成一台随身 AI 开发工作站
人工智能·macos·ai·大语言模型·ai编程·ai写需求
特长腿特长10 分钟前
Cherry Studio 通过 MCP 接口操作 Obsidian 完全指南
ai·obsidian·mcp
润乾软件21 分钟前
从 GUI 到 LUI 的进化,报表工具也有了 Copilot
人工智能·ai·copilot·报表工具
JaydenAI21 分钟前
[MAF预定义Agent中间件-03]FunctionInvocationDelegatingAgent:将AOP引入函数调用
ai·c#·agent·aop·maf
DS随心转插件24 分钟前
AI导出鸭深度评测:DeepSeek 转 Word 实战表现与边界分析
人工智能·ai·word·文心一言·deepseek·ai导出鸭
Artech26 分钟前
[MAF预定义ChatClient中间件-06]利用ImageGeneratingChatClient开发专业图片生成Agent
ai·agent·maf
yuhulkjv33528 分钟前
Kimi如何导出pdf | AI导出鸭 独家深度测评
人工智能·ai·chatgpt·pdf·ai导出鸭
FII工业富联科技服务43 分钟前
AI+3D世界模型:重构园区安防的“可感知、可推演、可进化”
大数据·人工智能·3d·ai·制造
stephon_1001 小时前
国产大模型 Agent 开发实战:用 milu 5 分钟搭一个多用户 AI Agent 服务(DeepSeek/Qwen/Kimi/GLM)
人工智能·python·ai·chatgpt