互联互通数据推送

本文涉及的产品
密钥管理服务KMS,1000个密钥,100个凭据,1个月
日志服务 SLS,月写入数据量 50GB 1个月
简介: 需求是基于治疗数据,推送给平台,使用xml对数据进行组装,同时进行加密,里面包含所有的治疗数据与pdf,而生成是在完成治疗后进行数据的推送。这个过程是实时的,因此就需要考虑性能的问题,同时不能影响主流程。因此使用异步进行数据的推送,同时对生成的pdf需要进行加密,放入xml中。而提前的数据信息使用并行流的方式对数据进行组装。这里主要解决推送过程的方式。下面是最近的需求和解决的思路和方式。

1.需求的产生

医院信息互联互通测评的项目应用评价分为七个等级,由低到高依次为一级、二级、三级、四级乙等、四级甲等、五级乙等、五级甲等,每个等级的要求由低到高逐级覆盖累加,即较高等级包含较低等级的全部要求。因此通常只要需要评级的医院,都离不开做互联互通,使用平台对医院的数据进行联网。因此,就有了下面的需求,完成与平台的互联互通。

需求是基于治疗数据,推送给平台,使用xml对数据进行组装,同时进行加密,里面包含所有的治疗数据与pdf,而生成是在完成治疗后进行数据的推送。这个过程是实时的,因此就需要考虑性能的问题,同时不能影响主流程。因此使用异步进行数据的推送,同时对生成的pdf需要进行加密,放入xml中。而提前的数据信息使用并行流的方式对数据进行组装。这里主要解决推送过程的方式。下面是最近的需求和解决的思路和方式。

2.推送的类型

通常医院的数据推送分为两类:一类是和医院his、lis以及影像资料对接对接的数据,一类是和平台对接的数据。通常和医院对接的数据通常是规则的,同时数据可以采用MQ或者webservice进行对接,比如医嘱对接使用MQ进行对接。而和平台对接,通常是患者的治疗数据和pdf记录单等,此类数据通常使用webService的soap进行推送

3.推送过程思路

而这类数据通常是在xml中进行,因为推送的数据除了患者的基本治疗数据外和包含了一个pdf的信息,通常采用HL7协议进行数据的组装,此时就会涉及到对患者数据的组装,而组装的过程中,通常是在患者治疗下机后,就会产生记录单信息,而产生记录单信息的同时还需要对其进行pdf的生成,而生成后,根据生成的pdf路径,对pdf进行base64加密,然后在自定义的xml中组装节点元素,然后推送给平台,根据平台返回的想要信息,获取节点中返回的响应,然后进行确认,类似于ack确认;如果推送失败,则进行失败重试,如果重试失败,则将失败的信息记录到日志中,方便查看,然后进行人工干预,将数据进行手动推送。由于通常平台是根据国家要求,通常会使用基于卫生部的规范进行数据的cda规范推送。

4.推送的内容

而推送的过程包含两部分:一部分是注册xml信息,通常是由平台提供样例,然后根据样例进行xml节点元素的组装,另一部分是需要推送的数据信息,通常会包含两部分:一部分是患者的信息和患者的资料所有信息,采用soap方式进行推送。

5.推送的方式

下图是推送的数据方式:


微信图片_20221214032438.png

推送过平台的数据,通常平台会根据我们推送的数据,进行解析,通常会根据我们提供的治疗所有信息的样例,进行平台代码的编写,或者根据我们提供的治疗消息样例,进行修改,然后推送他们想要的数据。

为了方便消息丢失问题的出现,这里需要将我们的失败日志信息写入到数据库中,夜间根据失败的日志数据进行重推到平台中,防止我们推送的数据丢失的情况。

推送并响应:

微信图片_20221214032441.png


由于不同医院选择的互联互通的第三方平台,因此互联互通方案也会存在一定的差异性。

6.接口信息

平台那边需要的数据:

微信图片_20221214032446.png

从里面我们可以看到平台需要的接口信息、接口名称、接口方法、参数信息、要发送的消息、返回信息。

根据他们提供的消息样例组装xml信息,然后进行推送。

cda文档类型,下面截图部分:

微信图片_20221214032449.png

以上只是一部分,而这些cda的数据,通常都是医院的不同系统建立起来的。

对于推送,里面最重要的就是message,上面提到的参数里面。

也即我们想在需要做的就是将消息中需要的信息拿到,然后根据拿到的信息进行组装:

通常组装的xml中:下面截取xml中的一小部分内容,下面的数据有修改。

<RCMR_IN000002UV02ITSVersion="XML_1.0"xmlns="urn:hl7-org:v3"xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"xsi:schemaLocation="urn:hl7-org:v3 ../multicacheschemas/RCMR_IN000002UV02.xsd"><idroot="3.2.5.1.1"extension="200200000000728"></id><creationTimevalue="20210430165413"></creationTime><interactionIdroot="3.2.5.1.2"extension="RCMR_IN000002UV02"></interactionId><processingCodecode="P"></processingCode><processingModeCode></processingModeCode><acceptAckCodecode="AL"></acceptAckCode><receivertypeCode="RCV">   ...
</receiver><sendertypeCode="SND">    ...
</sender><controlActProcessclassCode="STC"moodCode="APT"><subjecttypeCode="SUBJ"><clinicalDocumentclassCode="DOCCLIN"moodCode="EVN"><id><itemroot="3.2.5.1.24"extension="900200000000728"></item></id><codecode="EMR-SD-08"codeSystem="3.2.5.1.23"codeSystemName="文档类型代码"><displayNamevalue="治疗记录"></displayName></code>       ...
<versionNumbervalue="1"></versionNumber><storageCode><!--需要存储的加密信息 --><originalTextvalue=""></originalText><translation></translation></storageCode>      ...
</clinicalDocument>        ...
</subject></controlActProcess></RCMR_IN000002UV02>

而组装的方式可以是采用最为直接的stringbuffer进行组装,但是这样的话,容易产生硬编码的现象,同时扩展性的话,不够直接,但是如果是采用节点组装的方式,这样的话,下次进行扩展的时候会方便一些。其实xml的组装在安卓用得比较多。组装的方式采用xml属性和xml元素的方式进行组装,通常属性是xml标签里面的属性信息,而xml元素则是可以放入元素+属性信息,从而进行进一步的节点组装。同时我发现如果他们提供的样例如果节点设置并列关系多一点,数据结构的组装会方便很多,但是当时他们提供的组装样例麻烦,因此写出来的组装相对来说,嵌套会多一些。

@XmlAccessorType(XmlAccessType.FIELD)
@XmlRootElement(name="RCMR_IN000002UV02", namespace="urn:hl7-org:v3")
publicclassRCMR_IN000002UV02 {
@XmlAttribute(name="xmlns")
publicStringxmlns="urn:hl7-org:v3";
@XmlAttribute(name="xmlns:xsi")
publicStringxsi="http://www.w3.org/2001/XMLSchema-instance";
@XmlAttribute(name="xsi:schemaLocation")
publicStringschemaLocation="urn:hl7-org:v3 ../multicacheschemas/RCMR_IN000002UV02.xsd";
@XmlElement(name="id")
publicNodeAttrid;
@XmlElement(name="creationTime")
publicNodeAttrcreationTime;
@XmlElement(name="interactionId")
publicNodeAttrinteractionId;
    ...
// 省略get/set    }

属性信息使用 @XmlAttribute和元素信息@XmlElement对元素关系和元素结构进行组装,然后就可以构建好自定义的xml。

组装完数据,接着是对平台响应的xml信息进行获取,然后进行确认,如果成功,则不做处理,如果失败,则将失败的患者治疗id信息和治疗时间进行记录,存入失败表中,然后在晚上使用定时任务将失败的数据信息进行同步。除此之外,还将失败的数据信息打到日志管理界面中,日志管理界面通常会保存两个星期的审计日志数据。同时提供界面给实施人员进行下载,方便排查问题和反馈给开发进行解决。

<acceptAckCodecode="AL"/><receivertypeCode="RCV"><deviceclassCode="DEV"determinerCode="INSTANCE">    ....
</device></receiver><sendertypeCode="SND"><deviceclassCode="DEV"determinerCode="INSTANCE">    ....
</device></sender><!--处理结果,比如AA是成功,AF是失败--><acknowledgementtypeCode="AA"><!--请求消息ID--><targetMessage><idroot="3.2.5.1.1"extension="请求的消息 ID"/></targetMessage><!--处理结果说明--><acknowledgementDetail><textvalue="处理结果说明"/></acknowledgementDetail></acknowledgement></MCCI_IN000002UV01>

这里可以基于其返回的处理结果,进行确认对方是否收到了发过去的数据,这个结果类似于我们进行手动ack确认的依据。此时拿到处理结果:

Documentdoc=DocumentHelper.parseText(s);
Elementroot=doc.getRootElement();
Elementresponse=root.element("acknowledgement");
//拿到处理结果response.attribute("typeCode").getValue();

进行判断,从而进行相应的处理。

7.总结

而推送的过程中涉及到治疗信息的pdf生成和加密以及xml的组装,同时将信息放入到xml中过程。为了不影响主流程业务,通常我们会使用异步的方式进行消息的推送,因此我们这里使用线程池对其进行推送,数据的获取使用并行流的方式。当然,除了自己拼接xml进行解析外,还可以使用xstream进行解析。

目录
相关文章
|
9天前
|
新零售 自然语言处理 监控
云端问道23期—方案讲解
今天跟大家主要去讲一下多模态数据信息提取的技术解决方案。那么整体我们在讲的过程中,大概有以下七个方面。 1. 技术解决方案概述 2. 客户使用商业场景 3. 行业应用分析 4. 客户案例展示 5. 商业价值与效益 6. 实践落地案例 7. 技术未来展望
|
7月前
|
存储 监控 安全
个人数据在云端是否安全?
【6月更文挑战第23天】个人数据在云端是否安全?
99 5
|
存储 安全 网络协议
IoT亿级设备接入层建设实践
互联网的产品基本都需要解决终端的接入问题,每个接入层会因为终端数量、终端能力、网络环境等不同的因素有各自的设计特性。物联网场景下由于IoT设备的特点,不同的&quot;物&quot;特性催生了不同的IoT接入层。本文详细介绍了阿里云IoT在接入层的一些关键策略和设计。
1376 0
|
传感器 物联网 智能硬件
IoT设备与手机App之间实时消息通信解决方案
PLC 工控机和管理人员 App 的联动
1588 15
IoT设备与手机App之间实时消息通信解决方案
EMQ
|
存储 缓存 Prometheus
Neuron 2.3.0 发布:更轻松地接入和管理海量工业设备
开源工业协议网关软件Neuron发布2.3.0版本,新增CIP Ethernet/IP、Mitsubishi Melsec 1E frame E71和Fanuc Focas三个协议驱动,帮助更多工业用户实现海量工业设备接入。
EMQ
232 0
Neuron 2.3.0 发布:更轻松地接入和管理海量工业设备
|
数据可视化 安全 前端开发
DingTalk「开发者说」 钉钉连接平台:打通企业数据孤岛的最佳实践
摘要:DingTalk「开发者说」是专为钉钉开发者打造的栏目,分享钉应用开发的实战技巧、技术架构、解决方案,致力于成为钉钉与开发者的连接桥梁。本篇主要介绍什么是钉钉连接平台,连接平台所具备的能力,可覆盖哪些高频场景的互联互通,以及连接平台的实战演示。
2176 1
DingTalk「开发者说」 钉钉连接平台:打通企业数据孤岛的最佳实践
|
存储 运维 安全
解读|阿里云IoT亿级设备接入层如何建设实践
"物"的种类非常多,应用场景、成本各不同,比如水表一般安装在户外,一般采用电池供电,这种设备对能耗的要求非常苛刻,比如基站铁塔的后备电源,一般安装在荒野,这种设备对网络的要求非常苛刻,比如开关,这种设备对存储、内存、cpu的要求非常苛刻,不同的"物"特性催生了不同的IoT接入层,下面来看看IoT接入层需要做什么?
解读|阿里云IoT亿级设备接入层如何建设实践
|
SQL 网络协议 Java
阿里云物联网平台之利用云平台流转如何实现同一款产品下任意俩个设备的通信?
大部分同学应该都知道这种正常的基于云平台流转的M2M设备间通信,可以指定A产品的某个设备的消息流转到B产品的某个设备,或者从B产品的某个设备流转到A产品的某个设备,具有一定的指向性。 那么如何才能够体现任意俩个字呢?假设把产品下每个产品都当成群成员,如何才能让他们之间自由的发言呢? 也就是说我如何只配置一条规则,就可以实现这个产品下的设备进行自由通信,而不是A->B要配置一条规则,B->C还要配置一条规则,甚至B->A也要配置一条规则。
1260 15
阿里云物联网平台之利用云平台流转如何实现同一款产品下任意俩个设备的通信?
|
存储 NoSQL Redis
设备接入--LiveNvr平台的对接
青柿视频流媒体服务
376 0
设备接入--LiveNvr平台的对接
|
供应链
阿里云端到端的智能货品解决方案
阿里云端到端的智能货品解决方案
200 0