0

0

C# FHIR资源文件 C#如何序列化和反序列化HL7 FHIR的JSON或XML文件

月夜之吻

月夜之吻

发布时间:2026-03-04 09:54:58

|

834人浏览过

|

来源于php中文网

原创

最稳妥方式是直接用fhirjsonserializer序列化fhir资源为json,需设置resourceformat.json、确保resourcetype已初始化,并注册自定义extension;xml反序列化须严格校验命名空间;json反序列化失败主因是版本不匹配或字段格式异常,应启用ignoreunknownelements等设置。

c# fhir资源文件 c#如何序列化和反序列化hl7 fhir的json或xml文件

FhirJsonSerializer 序列化 FHIR 资源为 JSON

直接调用 FhirJsonSerializer 是最稳妥的方式,它内置了 FHIR 版本感知、类型映射和扩展处理逻辑。别自己用 JsonConvert.SerializeObject 硬转——FHIR 资源里大量使用 ElementBackboneElement 和动态 Extension,手动序列化会丢字段或格式错乱。

  • 必须先设置 FhirJsonSerializerSettingsResourceFormatResourceFormat.Json(默认就是,但显式写上更安全)
  • 确保资源实例的 ResourceType 已正确初始化(比如 new Patient() 会自动设,但空构造后手动赋值 Id 不会触发)
  • 如果资源含自定义 Extension,需提前注册:调用 FhirSerializationUtil.RegisterCustomElement<myextensiontype>()</myextensiontype>
  • 示例:
    FhirJsonSerializer serializer = new FhirJsonSerializer();
    string json = serializer.SerializeToString(patient);

FhirXmlSerializer 反序列化 XML 到 C# 对象

XML 反序列化比 JSON 更容易出错,主因是命名空间和元素顺序敏感。FHIR XML 必须带 xmlns="http://hl7.org/fhir",缺这个命名空间会导致 FhirXmlSerializer.Deserialize<patient>(xml)</patient> 返回 null 或抛 InvalidOperationException

  • 传入的 XML 字符串开头必须包含完整的根命名空间声明,不能只靠 <patient></patient> 简写
  • 不要用 XDocument.Load + 手动提取再反序列化——FhirXmlSerializer 内部依赖完整文档上下文
  • 若 XML 来自外部系统且命名空间不规范(比如用了前缀 fhir:),先做预处理替换:把 fhir:PatientPatient,并补全默认命名空间
  • 示例:
    string xml = @"<Patient xmlns=""http://hl7.org/fhir""><id value=""123""/></Patient>";
    FhirXmlSerializer xmlSer = new FhirXmlSerializer();
    Patient p = xmlSer.Deserialize<Patient>(xml);

JSON 反序列化失败常见原因和绕过方法

最常见的报错是 Newtonsoft.Json.JsonSerializationException: Cannot create and populate list type Hl7.Fhir.Model.List`1,本质是 JSON 中某个数组字段类型不匹配(比如服务器返回了 "identifier": [],但 SDK 期望 "identifier": [{}])。

云雀语言模型
云雀语言模型

云雀是一款由字节跳动研发的语言模型,通过便捷的自然语言交互,能够高效的完成互动对话

下载
  • 优先检查 FHIR 版本是否对齐:.NET SDK 的 Hl7.Fhir.R4 包只能处理 R4 JSON,拿 STU3 的 JSON 去反序列化必崩
  • 遇到未知字段(如服务端加了非标准扩展字段),在 FhirJsonSerializerSettings 中启用 IgnoreUnknownElements = true
  • 若 JSON 含时间字段格式不标准(如 "2023-10-05T14:30" 缺少秒或时区),设置 DateTimeStyle = DateTimeStyle.RoundTrip
  • 别 catch JsonSerializationException 后吞掉——它通常意味着数据结构损坏,应记录原始 JSON 用于排查

性能与线程安全注意事项

FhirJsonSerializerFhirXmlSerializer 实例本身不是线程安全的,但可以复用。反复 new 它们不会显著拖慢,但没必要;而共享单例时要注意内部缓存状态。

  • 推荐每线程一个实例,或用 static readonly 声明(只要不修改其 Settings 属性)
  • 序列化大资源(如含数百个 ObservationBundle)时,避免在 Web API action 中同步调用 SerializeToString——改用 SerializeToStreamAsync 配合 HttpResponse.Body
  • XML 序列化比 JSON 慢约 3–5 倍,仅在必须兼容旧系统时用;日常接口尽量走 JSON
  • 如果频繁转换同一类资源(比如总在处理 Condition),可预先调用 FhirSerializer.PrepareForType<condition>()</condition> 加速首次序列化

实际用的时候,最容易被忽略的是 FHIR 版本绑定和命名空间校验——两个看似“应该能通”的文件,往往卡在这两处。多打一行日志输出 resource.ResourceTypexml.Contains("xmlns="),省掉半天排查。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
json数据格式
json数据格式

JSON是一种轻量级的数据交换格式。本专题为大家带来json数据格式相关文章,帮助大家解决问题。

452

2023.08.07

json是什么
json是什么

JSON是一种轻量级的数据交换格式,具有简洁、易读、跨平台和语言的特点,JSON数据是通过键值对的方式进行组织,其中键是字符串,值可以是字符串、数值、布尔值、数组、对象或者null,在Web开发、数据交换和配置文件等方面得到广泛应用。本专题为大家提供json相关的文章、下载、课程内容,供大家免费下载体验。

546

2023.08.23

jquery怎么操作json
jquery怎么操作json

操作的方法有:1、“$.parseJSON(jsonString)”2、“$.getJSON(url, data, success)”;3、“$.each(obj, callback)”;4、“$.ajax()”。更多jquery怎么操作json的详细内容,可以访问本专题下面的文章。

328

2023.10.13

go语言处理json数据方法
go语言处理json数据方法

本专题整合了go语言中处理json数据方法,阅读专题下面的文章了解更多详细内容。

81

2025.09.10

c语言中null和NULL的区别
c语言中null和NULL的区别

c语言中null和NULL的区别是:null是C语言中的一个宏定义,通常用来表示一个空指针,可以用于初始化指针变量,或者在条件语句中判断指针是否为空;NULL是C语言中的一个预定义常量,通常用来表示一个空值,用于表示一个空的指针、空的指针数组或者空的结构体指针。

252

2023.09.22

java中null的用法
java中null的用法

在Java中,null表示一个引用类型的变量不指向任何对象。可以将null赋值给任何引用类型的变量,包括类、接口、数组、字符串等。想了解更多null的相关内容,可以阅读本专题下面的文章。

988

2024.03.01

resource是什么文件
resource是什么文件

Resource文件是一种特殊类型的文件,它通常用于存储应用程序或操作系统中的各种资源信息。它们在应用程序开发中起着关键作用,并在跨平台开发和国际化方面提供支持。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

175

2023.12.20

pdf怎么转换成xml格式
pdf怎么转换成xml格式

将 pdf 转换为 xml 的方法:1. 使用在线转换器;2. 使用桌面软件(如 adobe acrobat、itext);3. 使用命令行工具(如 pdftoxml)。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

1940

2024.04.01

PHP高性能API设计与Laravel服务架构实践
PHP高性能API设计与Laravel服务架构实践

本专题围绕 PHP 在现代 Web 后端开发中的高性能实践展开,重点讲解基于 Laravel 框架构建可扩展 API 服务的核心方法。内容涵盖路由与中间件机制、服务容器与依赖注入、接口版本管理、缓存策略设计以及队列异步处理方案。同时结合高并发场景,深入分析性能瓶颈定位与优化思路,帮助开发者构建稳定、高效、易维护的 PHP 后端服务体系。

4

2026.03.04

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
WEB前端教程【HTML5+CSS3+JS】
WEB前端教程【HTML5+CSS3+JS】

共101课时 | 9.9万人学习

JS进阶与BootStrap学习
JS进阶与BootStrap学习

共39课时 | 3.3万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号