村田EDI项目技术细节分享

2020-11-11 10:09:18 浏览数 (2)

此前的文章中完整介绍了对接村田EDI项目的实施过程,详细过程可参考文章: Murata村田EDI项目实施 接下来将针对EDI项目的两个技术细节进行分享,主要介绍在EDI系统中实现状态回传以及将XML文件转换为CSV文件。

状态回传

项目实施过程中,需要明确数据是否已成功发送给交易伙伴。以防止数据漏发、错发给业务带来不必要的损失。

本次EDI项目采用了中间数据库解决方案。status列可以用来标志每行数据的处理状态,如下图所示:status值为0表示新建状态,status值为1表示抓取成功状态,status值为2表示发送成功状态。接下来为大家详细介绍如何根据当前数据处理情况完成状态回传。

状态0状态0
状态1状态1
状态2状态2

1.从新建状态到数据库端口抓取成功状态,首先在数据库端口的Output 映射编辑器页面进行设置,如下图所示:

状态设置状态设置

经上述配置后,若数据库端口成功抓取数据,则status值由0更新至1。

2.将数据库端口抓取成功状态转换为AS2发送成功状态,需要在数据库端口和AS2端口增加状态回传脚本。

首先,从数据库获取数据后,查看.eml文件(文件路径为EDI系统的安装路径workspaceSend),其头部有一部分信息为固定值,随着xml文件一起传输。实现状态回传,需要将读取的status和id值写入.eml文件中。其次,在数据库端口的事件-接收后(After Recieve)页面下补充脚本。如下图:

数据库脚本数据库脚本

上图所示,在左下角的红色方框位置写入如下脚本:

数据库脚本数据库脚本

最后在AS2端口的事件-发送后(After Send)页面下补充脚本。如下图所示:

AS2脚本AS2脚本

在左下角红色方框位置补充如下代码:

AS2脚本AS2脚本

上述脚本添加完毕后,实现功能:当AS2成功发出文件后,status被更新为2,至此完成状态回传。

XML文件转为CSV文件

村田EDI项目需要将POS和PBI两种XML文件转换为CSV文件。接下来介绍XML文件转为CSV文件的流程。

CSV模板如下图所示:

CSV模板CSV模板

则需要设计如下图所示的目标文件模板。同一个Items内允许出现多个Item表示多组数据。

目标文件模板目标文件模板

转换分析:生成CSV文件时需要注意,要将XML文件转换为CSV文件,输入的XML必须具有“平面”结构。这意味着,不管根元素如何,XML结构的深度都是2。

如果输入的XML文件层级大于2,则无法转换为CSV格式。此时可以将头部信息放在明细信息下,简化层级结构。

传输过程中,头部信息只需出现一次,而明细信息可重复出现多次。在保证信息完整输出的前提下,将头部信息放在明细信息中既满足了XML转CSV的“平面”结构需求,又不影响业务数据输出的完整性。

村田EDI项目中,由于POS和PBI均需要转换为CSV文件,因此客户希望对这两种CSV文件进行标记。可以通过在第一行第一列增加标题栏进行区分。CSV模板如下图所示:

CSV模板CSV模板

修改上述模板,需要在EDI系统中修改XML Map端口中的目标文件。新增一行字段放于表头,不用增加任何的映射关系,即可生成上述CSV文件。

更多EDI技术交流,欢迎私信或评论!

注:文案部分图片及内容来源于网络,版权归原创作者所有,如有侵犯到您的权益,请您联系我们进行删除,给您带来困扰,我们深感抱歉。

0 人点赞