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 等)的处理,手动构建或加特异性前缀才是最稳妥的做法。

相关推荐
lincats4 小时前
Claude Code项目越写越乱?这套清理流程能救你
ai·ai agent·claude code
云燕实验室CloudLab8 小时前
《AI开始"抱团"思考了!多智能体 + 思维图到底有多强?》
ai·学习工具·智慧学伴
小七-七牛开发者8 小时前
论文解读:DeepSeek DSpark 在真实高并发推理服务中,如何保证 Token 生成又好又快?
ai·大模型·编程·ai coding
doiito14 小时前
【Agent Harness】Gliding Horse 核心设计理念,不跟风开发自己的AI Agent
ai·rust·架构设计·系统设计·ai agent
doiito2 天前
【Agent Harness】Gliding Horse 的 L2 作战地图:让多 Agent 协作从“摸黑”变成“透明”
ai·rust·架构设计·系统设计·ai agent
xiezhr2 天前
逛GitHub发现一款免费带有AI功能的数据库管理工具DBX
ai·开源软件·自然语言·数据库管理工具
Venuslite2 天前
从 Unexpected token < 到 Extra data:一次讲清 JSON 解析错误的排查思路
json
垚森3 天前
我用 GLM-5.2 造了个炸裂主题后台:16 套主题随心切,可在线体验
ai·react
doiito4 天前
【Agent Harness】Gliding Horse 工具结果压缩体系:如何用“指针”驯服上下文膨胀
ai·rust·架构设计·系统设计·ai agent
doiito5 天前
【Agent Harness】Gliding Horse 上下文动态感知与智能压缩:让 Agent 真正“听得进”每一句话
ai·rust·架构设计·系统设计·ai agent