在从业务角度解读彼欧Plastic Ominum EDI项目中的DELFOR报文一文中,已经对DELFOR报文中的业务值做了详细介绍。本文会从EDI技术实现角度出发,依照DELFOR报文在EDI系统中的解析流程进行详细的介绍。
1. EDI业务流
从上图中可以看出,EDI业务流中包含两种业务报文,分别是DELFOR(交付计划)和DESADV(发货通知)。实际业务中,首先是由彼欧Plastic Ominum 发送DELFOR(交付计划)给A供应商,随后,A供应商会生产、发货等,在发货环节,A供应商需要发送DESADV(发货通知)给彼欧Plastic Ominum ,通知收货方发出的货物情况,以便彼欧Plastic Ominum 做收货准备。
2. EDI工作流
接下来,看看在EDI系统中解析以及生成报文的过程。同业务流一样,在EDI工作流中,将传输方向不同的报文也独立开为接收报文和发送报文两个方向来做处理。项目中,客户选择的是Excel方式,即借助于EDI系统,将收到的DELFOR(交付计划)报文解析为Excel文件,之后发送给业务人员作进一步业务处理。相反地,发出的文件,首先由业务人员填写Excel空模板,完善DESADV(发货通知)业务中所需要的业务值,之后,经由EDI系统处理,生成符合EDIFACT标准的DESADV(发货通知)报文,并发出给彼欧Plastic Ominum 。
上图中,展示的是整个项目的EDI工作流情况。便于大家理解,以下分解为接收&解析DELFOR报文和生成&发出DESADV报文两部分,分别介绍。本文先对接收&解析DELFOR报文进行介绍,关于DESADV报文的详细介绍请参考“借助EDI系统实现彼欧Plastic Ominum EDI项目DESADV报文生成”一文。
2.1 接收&解析DELFOR报文工作流
如图所示,展示的是在知行EDI系统中接收&解析DELFOR报文工作流。
- PO_OFTP_SSID端口:通过互联网使用OFTP2.0传输协议与交易伙伴建立EDI连接,作为NA_OFTP_SFID端口的Routing Partner
- NA_OFTP_SFID端口:通过互联网使用OFTP2.0传输协议与交易伙伴建立EDI连接
- EDIToXMl端口:将EDIFACT标准的DELFOR(交付计划)报文转换为知行EDI系统标准的XML格式的交付计划文件
- DELFORToExcel端口:将以上转换得到的知行EDI系统标准的XML格式的交付计划文件转换为Excel格式的交付计划文件
- EmailSend端口:将以上得到的Excel格式的交付计划文件以邮件附件形式发送至A供应商的业务人员
可以看出,在知行EDI系统中,首先由负责建立OFTP连接的PO_OFTP_SSID端口和NA_OFTP_SFID端口收到DELFOR(交付计划)报文,之后依次经由EDIToXMl端口、DELFORToExcel端口完成文件格式转换,最终由EmailSend端口发送至业务人员。通过这些端口的配合,就完整地实现了接收并解析DELFOR报文的整个工作流。
3. DELFOR报文解析过程
将接收到的DELFOR报文转换为Excel格式交付计划,转换过程主要分为以下3个步骤。
3.1 EDIFACT标准的DELFOR报文
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 |
UNB+UNOA:2+000123456789PO+000987654321CD+181119:1355+176++FRNE' UNH+1+DELFOR:D:96A:UN:A09041' - DELFOR:报文类型为交付计划 BGM+34+0300001234+9' - 0300001234:Message No DTM+137:201911191355:203' - 201911191355:Message Date RFF+ADE:2012345' - 2012345:Supplier Account No NAD+BY+POABCPL12::92+PO AUTO' - POABCPL12:Customer Number - PO AUTO: Customer Name NAD+SE+987654321::10+A SUPPLIER' - 987654321:Supplier Number - A SUPPLIER: Supplier Name UNS+D' NAD+CN+PO123456000XX::92+PO AUTO ROAD 12345::123 ABC:PL++++++PL' - PO123456000XX:P.O. Plant Number - PO AUTO ROAD 12345:P.O. Plant Name LIN++3+20115179:IN' - 20115179:Part No IMD+++:::TEST 123456 ABC' - TEST 123456 ABC:Item Description LOC+11+45678' - 45678:Port of Discharge DTM+257:20191119:102' - 20191119:Calculation Date RFF+ON:1234567890' - 1234567890:Order No QTY+70:30000:PCE' - 30000:Cumul Received Quantity QTY+12:2000:PCE' - 2000:Dispatched Quantity RFF+AAK:20191106' - 20191106:Dispatch Advice Number DTM+171:20191116:102' - 20191116:Delivery Date QTY+113:200:PCE' - 200:Quantity to be Delivered SCC+1++Y' - 1:Firm DTM+63:20191120:102' - 20191120:Delivery Date Latest DTM+64:20191120:102' - 20191120:Delivery Date Earliest /-同上-/ QTY+113:500:PCE' SCC+4++Y' DTM+63:20191211:102' DTM+64:20191211:102' QTY+113:100:PCE' SCC+4++W' DTM+63:20191223:102' DTM+64:20191217:102' UNS+S' UNT+31+1' UNZ+1+33' |
3.2 由8DELFOR报文转化得到标准XML格式交付计划
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 200 201 202 203 204 205 206 207 208 209 210 211 212 213 214 215 216 217 218 219 220 221 222 223 224 225 226 227 228 229 230 231 232 233 234 235 236 237 238 239 240 241 242 243 244 245 246 247 248 249 250 251 252 253 254 255 256 257 258 259 260 261 262 263 264 265 266 267 268 269 270 271 272 273 274 275 276 277 278 279 280 281 282 |
<Interchange Delimiters=":+.?*';" xmlns="http://www.rssbus.com" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"> <Meta /> <UNB1 type="Composite"> <UNB1.1>UNOA</UNB1.1> <UNB1.2>2</UNB1.2> </UNB1> <UNB2 type="Composite"> <UNB2.1>000123456789PO</UNB2.1> </UNB2> <UNB3 type="Composite"> <UNB3.1>000987654321CD</UNB3.1> </UNB3> <UNB4 type="Composite"> <UNB4.1>181119</UNB4.1> <UNB4.2>1355</UNB4.2> </UNB4> <UNB5>176</UNB5> <UNB6 type="Composite"> </UNB6> <UNB7>FRNE</UNB7> </Meta> <TransactionSet> <TX-D96A-DELFOR type="TransactionSet"> <Meta /> <_0062>1</_0062> <S009 type="Composite"> <_0065>DELFOR</_0065> <_0052>D</_0052> <_0054>96A</_0054> <_0051>UN</_0051> <_0057>A09041</_0057> </S009> </Meta> <BGM type="Segment"> <C002 type="Composite"> <_1001>34</_1001> </C002> <_1004>0300001234</_1004> <_1225>9</_1225> </BGM> <DTM type="Segment"> <C507 type="Composite"> <_2005>137</_2005> <_2380>201911191355</_2380> <_2379>203</_2379> </C507> </DTM> <RFFLoop1 type="Loop"> <RFF type="Segment"> <C506 type="Composite"> <_1153>ADE</_1153> <_1154>2012345</_1154> </C506> </RFF> </RFFLoop1> <NADLoop1 type="Loop"> <NAD type="Segment"> <_3035>BY</_3035> <C082 type="Composite"> <_3039>POABCPL12</_3039> <_1131></_1131> <_3055>92</_3055> </C082> <C058 type="Composite"> <_3124>PO AUTO</_3124> </C058> </NAD> </NADLoop1> <NADLoop1 type="Loop"> <NAD type="Segment"> <_3035>SE</_3035> <C082 type="Composite"> <_3039>987654321</_3039> <_1131></_1131> <_3055>10</_3055> </C082> <C058 type="Composite"> <_3124>A SUPPLIER</_3124> </C058> </NAD> </NADLoop1> <UNS type="Segment"> <_0081>D</_0081> </UNS> <NADLoop2 type="Loop"> <NAD type="Segment"> <_3035>CN</_3035> <C082 type="Composite"> <_3039>PO123456000XX</_3039> <_1131></_1131> <_3055>92</_3055> </C082> <C058 type="Composite"> <_3124>PO AUTO ROAD 12345</_3124> <_3124></_3124> <_3124>123 ABC</_3124> <_3124>PL</_3124> </C058> <C080 type="Composite"> </C080> <C059 type="Composite"> </C059> <_3164/> <_3229/> <_3251/> <_3207>PL</_3207> </NAD> <LINLoop1 type="Loop"> <LIN type="Segment"> <_1082/> <_1229>3</_1229> <C212 type="Composite"> <_7140>20115179</_7140> <_7143>IN</_7143> </C212> </LIN> <IMD type="Segment"> <_7077/> <_7081/> <C273 type="Composite"> <_7009></_7009> <_1131></_1131> <_3055></_3055> <_7008>TEST 123456 ABC</_7008> </C273> </IMD> <LOC type="Segment"> <_3227>11</_3227> <C517 type="Composite"> <_3225>45678</_3225> </C517> </LOC> <DTM type="Segment"> <C507 type="Composite"> <_2005>257</_2005> <_2380>20191119</_2380> <_2379>102</_2379> </C507> </DTM> <RFFLoop2 type="Loop"> <RFF type="Segment"> <C506 type="Composite"> <_1153>ON</_1153> <_1154>1234567890</_1154> </C506> </RFF> </RFFLoop2> <QTYLoop1 type="Loop"> <QTY type="Segment"> <C186 type="Composite"> <_6063>70</_6063> <_6060>30000</_6060> <_6411>PCE</_6411> </C186> </QTY> </QTYLoop1> <QTYLoop1 type="Loop"> <QTY type="Segment"> <C186 type="Composite"> <_6063>12</_6063> <_6060>2000</_6060> <_6411>PCE</_6411> </C186> </QTY> <RFFLoop3 type="Loop"> <RFF type="Segment"> <C506 type="Composite"> <_1153>AAK</_1153> <_1154>20191106</_1154> </C506> </RFF> <DTM type="Segment"> <C507 type="Composite"> <_2005>171</_2005> <_2380>20191116</_2380> <_2379>102</_2379> </C507> </DTM> </RFFLoop3> </QTYLoop1> <QTYLoop1 type="Loop"> <QTY type="Segment"> <C186 type="Composite"> <_6063>113</_6063> <_6060>200</_6060> <_6411>PCE</_6411> </C186> </QTY> <SCC type="Segment"> <_4017>1</_4017> <_4493/> <C329 type="Composite"> <_2013>Y</_2013> </C329> </SCC> <DTM type="Segment"> <C507 type="Composite"> <_2005>63</_2005> <_2380>20191120</_2380> <_2379>102</_2379> </C507> </DTM> <DTM type="Segment"> <C507 type="Composite"> <_2005>64</_2005> <_2380>20191120</_2380> <_2379>102</_2379> </C507> </DTM> </QTYLoop1> <QTYLoop1 type="Loop"> <QTY type="Segment"> <C186 type="Composite"> <_6063>113</_6063> <_6060>500</_6060> <_6411>PCE</_6411> </C186> </QTY> <SCC type="Segment"> <_4017>4</_4017> <_4493/> <C329 type="Composite"> <_2013>Y</_2013> </C329> </SCC> <DTM type="Segment"> <C507 type="Composite"> <_2005>63</_2005> <_2380>20191211</_2380> <_2379>102</_2379> </C507> </DTM> <DTM type="Segment"> <C507 type="Composite"> <_2005>64</_2005> <_2380>20191211</_2380> <_2379>102</_2379> </C507> </DTM> </QTYLoop1> <QTYLoop1 type="Loop"> <QTY type="Segment"> <C186 type="Composite"> <_6063>113</_6063> <_6060>100</_6060> <_6411>PCE</_6411> </C186> </QTY> <SCC type="Segment"> <_4017>4</_4017> <_4493/> <C329 type="Composite"> <_2013>W</_2013> </C329> </SCC> <DTM type="Segment"> <C507 type="Composite"> <_2005>63</_2005> <_2380>20191223</_2380> <_2379>102</_2379> </C507> </DTM> <DTM type="Segment"> <C507 type="Composite"> <_2005>64</_2005> <_2380>20191217</_2380> <_2379>102</_2379> </C507> </DTM> </QTYLoop1> </LINLoop1> </NADLoop2> <UNS type="Segment"> <_0081>S</_0081> </UNS> </TX-D96A-DELFOR> </TransactionSet> </Interchange> |
3.3 由标准XML格式交付计划转化得到Excel格式交付计划
注:文案部分图片及内容来源于网络,版权归原创作者所有,如有侵犯到您的权益,请您联系我们进行删除,给您带来困扰,我们深感抱歉。
发表评论
要发表评论,您必须先登录。