BMW配送流程:通过EDI对接VDLP

BMW的汽车配送流程始于汽车“生产结束”,结束于“交付给宝马经销商”。BMW与其物流服务供应商之间没有直接的接口,EDI信息将会通过BMW的EDI供应商提供的VDLP(车辆分销物流平台)进行交换。

近期我们收到来自国内某汽车行业供应商L公司的需求:由于BMW更换了物流服务供应商,因此需要按照最新要求,通过EDI实现配送流程中的单据传输。

VDLP EDI 需求总览
传输协议

SFTP

传输数据标准

XML

传输的业务单据

VDLP发送给L公司:FV14(车辆运输订单),其中包含文件类型、文件ID、发送方以及接收方ID、货代ID、货代地址信息、发货方地址信息、收货方地址信息、运输方式、运输要求、发货时间、最终目的地等信息。

车辆运输订单将会涉及到两种类型:

EarlyVehicleTransportOrder表示初步/早期车辆运输订单,如果收到这种车辆运输订单,则不需要回复FV17。

VehicleTransportOrder 表示车辆运输订单,如果收到这种订单,需要根据订单信息,回复对应的FV17。

L公司发送给VDLP:FV17(车辆运输状态报告),其中包含文件类型、文件ID、发送方以及接收方ID、货代ID、提单号、装箱单号、运输方式、运输要求、运输工具信息、集装箱信息、卸货地点以及装货地点等信息。

L公司需要分别在刚发货以及货物到达两个时间节点向VDLP发送FV17。

在EDI传输过程中,VDLP要求必须通过SFTP传输协议传输XML形式的业务数据。L公司发送给VDLP的文件名并没有特殊要求,VDLP发出的文件会将文件类型体现在文件名中,例如:VehicleTransportOrder_#########.XML,#号位置一般是由具有唯一性的数字组成。

VDLP EDI 对接解决方案

VDLP_EDI_case1.png

与VDLP搭建SFTP传输通道

SFTP(SSH File Transfer Protocol)安全文件传输协议,与FTP有着几乎一样的语法和功能。SFTP服务器有三种认证方式:密码,公钥以及多重认证方式。在与VDLP的EDI项目中,采用密码认证。

点击SFTP端口,在弹框页面中找到 设置,在这个页面中配置VDLP的SFTP连接信息,包括主机名称或地址、远程主机端口。在客户端认证中,需要配置登录SFTP的用户名和密码,服务器认证部分配置服务器指纹(表示SFTP服务器的证书指纹,也可以设置为包含服务器公钥的证书文件)。高级设置中可以修改SFTP本地文件夹所在的位置。

VDLP_EDI_case2.png

格式转换

由于本次EDI项目中传输的是XML格式,需要通过XMLMap端口实现VDLP要求的XML与数据库XML之间的格式转换。

系统集成

L公司内部具有业务系统,因此可以通过数据库中间表的方式实现业务系统与知行之桥EDI系统之间的格式转换。采用一张或多张数据库表作为中间表,存放知行之桥EDI系统收到EDI报文后解析所得的业务数据,以及发送EDI报文需要ERP提供的数据。中间数据库表,顾名思义它不等于ERP系统的生产数据库表,ERP仅在这个数据库中存放EDI发送报文所需的业务数据,和读取EDI接收的业务数据。

知行之桥EDI系统和ERP系统,通过各自的接口来连接中间数据库表,实现从中间数据库表中存放和读取数据。下图所示便是知行之桥EDI系统中的数据库端口,用于配置数据库表信息,完成与中间数据库表的连接。目前支持的数据库有:MySQL、PostgreSQL、SQLite、SQL Server、Oracle等。在本次项目中选择的数据库为Oracle。

我们的EDI 实施顾问会根据VDLP提供的XML规范文件整理需要传输的业务信息,与L公司的业务人员共同协商需要的字段信息。在跟客户确认业务字段后,ERP和EDI工程师沟通数据库表的结构,根据字段的主从关系来定主从表的结构,确认最终的数据库表结构,进行数据库建表,并进行测试。

了解更多 EDI 信息,请参阅: EDI 是什么?

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/746663.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

ISIS多区域实验简述

为支持大型路由网络,IS-IS在路由域内采用两级分层结构。 IS-IS网络中三种级别的路由设备:将Level-1路由设备部署在区域内,Level-2路由设备部署在区域间,Level-1-2路由设备部署在Level-1和Level-2路由设备的中间。 实验拓扑图&…

Spring中的注释

Resource注释 Resource private AService aService;This annotation may be applied to an application component class, or to fields or methods of the component class. When the annotation is applied to a field or method, the container will inject an instance of…

Linux字符设备与I2C驱动结合使用

引言 在Linux操作系统中,设备驱动程序充当硬件和软件之间的桥梁。字符设备驱动是一种特殊类型的驱动,它允许用户以字节流的形式访问硬件设备。这些设备包括键盘、鼠标、串口等。在本博客中,我们将探讨Linux字符设备驱动的基础知识&#xff0…

学生时期学习资源同步-JavaSE理论知识

原创作者:田超凡(程序员田宝宝) 版权所有,引用请注明原作者,严禁复制转载 选择题 (针对以下题目,请选择最符合题目要求的答案,针对每一道题目,所有答案都选对&#x…

Android APP启动优化

临时抱佛脚:IdleHandler 的原理分析和妙用 - 知乎 大致的流程是这样的: 如果本次循环拿到的 Message 为空,或者这个 Message 是一个延时的消息而且还没到指定的触发时间,那么,就认定当前的队列为空闲状态。接着就会遍…

LeetCode每日一题 将有序数组转换为二叉搜索树(分治)

题目描述 给你一个整数数组 nums ,其中元素已经按 升序 排列,请你将其转换为一棵平衡二叉搜索树。 示例 1: 输入:nums [-10,-3,0,5,9] 输出:[0,-3,9,-10,null,5] 解释:[0,-10,5,null,-3,null,9] 也将被视…

49、C++/友元、常成员函数和常对象、运算符重载学习20240314

一、封装类 用其成员函数实现&#xff08;对该类的&#xff09;数学运算符的重载&#xff08;加法&#xff09;&#xff0c;并封装一个全局函数实现&#xff08;对该类的&#xff09;数学运算符的重载&#xff08;减法&#xff09;。 代码&#xff1a; #include <iostream…

力扣刷题 Days18-第二题-完全二叉树的节点个数(js)

1,题目 给你一棵 完全二叉树 的根节点 root &#xff0c;求出该树的节点个数。 完全二叉树 的定义如下&#xff1a;在完全二叉树中&#xff0c;除了最底层节点可能没填满外&#xff0c;其余每层节点数都达到最大值&#xff0c;并且最下面一层的节点都集中在该层最左边的若干位…

【CFD小工坊】尝试完成一个简单的溃坝流算例(2)——get_val系列函数

【CFD小工坊】尝试完成一个简单的溃坝流算例&#xff08;2&#xff09;——get_val系列函数 前言设计思路代码讲解get_int_val函数Trim函数其余get系列函数 前言 在上一个博文《尝试完成一个简单的溃坝流算例&#xff08;1&#xff09;》中&#xff0c;我们提到了gat_val系列函…

有没有能用蓝牙的游泳耳机?四大年度最佳游泳耳机由衷推荐

随着科技的不断发展&#xff0c;游泳爱好者们对于游泳耳机的追求也越来越高。在游泳过程中&#xff0c;音乐和播客是许多泳者们的最佳伴侣&#xff0c;它能帮助他们保持节奏、提高兴趣。然而&#xff0c;传统的有线耳机在水下容易产生拉扯&#xff0c;不仅影响游泳体验&#xf…

【Linux操作系统】:Linux进程概念(2)

一、Z(zombie)-僵尸进程 1.僵尸进程概念 故事 张三每天都有跑步的习惯&#xff0c;这一天他和往常一样跑步&#xff0c;跑了两三圈&#xff0c;突然跑在它前面的一个人倒在地上不动了&#xff0c;作为热心市民张三赶紧报警并且拨打120。很快120就来了&#xff0c;但是没过几分…

使用 QLoRA 在 Google Colab 中微调 Mistral 7b(完整指南)

使用 QLoRA 在 Google Colab 中微调 Mistral 7b&#xff08;完整指南&#xff09; 在本文中&#xff0c;我们将在一个名为 Enlighten 的游戏的整个代码库上微调 Mistral 7b&#xff0c;所有这些都在 Google Colab&#xff08;或 Kaggle&#xff09;中免费提供合成数据。在我们的…

深度学习 精选笔记(11)深度学习计算相关:GPU、参数、读写、块

学习参考&#xff1a; 动手学深度学习2.0Deep-Learning-with-TensorFlow-bookpytorchlightning ①如有冒犯、请联系侵删。 ②已写完的笔记文章会不定时一直修订修改(删、改、增)&#xff0c;以达到集多方教程的精华于一文的目的。 ③非常推荐上面&#xff08;学习参考&#x…

中科数安 | 企业办公透明加密系统,终端文件数据 \ 资料防泄密管理软件

#公司办公文件数据 \ 资料防泄密软件系统# "中科数安"是一家专注于数据安全领域的公司&#xff0c;其提供的企业办公加密系统是一种针对企事业单位内部数据安全需求而设计的解决方案。该系统通过先进的加密技术&#xff0c;对企业在日常办公过程中产生的各类敏感信息…

浙大版《数据结构学习与实验指导(第2版)》笛卡尔树

笛卡尔树 题目描述 笛卡尔树是一种特殊的二叉树&#xff0c;其结点包含两个关键字K1和K2。首先笛卡尔树是关于K1的二叉搜索树&#xff0c;即结点左子树的所有K1值都比该结点的K1值小&#xff0c;右子树则大。其次所有结点的K2关键字满足优先队列&#xff08;不妨设为最小堆&am…

实景剧本杀小程序开发搭建

开发搭建实景剧本杀小程序需要以下步骤&#xff1a; 1. 确定小程序的开发语言和框架&#xff1a;根据项目需求和小程序的功能选择合适的开发语言和框架&#xff0c;如微信小程序、React Native等。 2. 设计小程序界面和功能&#xff1a;根据项目需求设计小程序界面和功能&…

MySQL--索引常见面试题详解

索引的设计原则&#xff1f; 在 where 子句中出现的列&#xff0c;建议设计索引。基数较小的列&#xff0c;不建议设计索引。尽量只用短索引&#xff0c;可以节省索引空间。不要过度索引&#xff0c;多设计联合索引&#xff0c;因为索引也有时间和空间的消耗。 创建索引需要注…

【css面试题】弹性盒布局模型 flex 全部知识点整理

一、基本语法 flex-basis 在分配多余空间之前&#xff0c;占据的主轴空间&#xff0c;相当于 widthflex-grow 定义项目的放大比例(存在剩余空间是否放大)默认为0 &#xff08;即如果存在剩余空间也不放大&#xff09;flex-shrink 定义项目的缩小比例&#xff08;空间不足&…

Mysql隔离级别的实现

Mysql隔离级别的实现 mysql隔离级别是通过MVCC锁来实现的&#xff0c;MVCC用来实现读已提交、可重复读 Mysql幻读的解决 1.针对快照读&#xff0c;通过 MVCC 方式解决了幻读 补充:串行化所有的数据库都没做&#xff0c;不过mvcc实现的效果跟串行化差不太多了&#xff0c;可以…

突飞猛进,智能饮品机器人如何助力实体经济?

近日&#xff0c;财务部公布了2024年第一季度及全年财报。数据显示&#xff0c;连锁品牌增长速度惊人&#xff0c;这其中不得不提到智能饮品机器人的使用&#xff0c;为不同的品牌门店拼速度、抢点位立下了不小的功劳&#xff0c;那么智能饮品机器人到底如何助力各门店&#xf…