2016-09-13 22 views
1

我想读取EDI消息并将其转换为Java对象,但我以下面的异常结束。EDI流到Java对象转换的异常

线程“main”中的异常org.milyn.SmooksException:未能过滤 源。在 org.milyn.delivery.sax.SmooksSAXFilter.doFilter(SmooksSAXFilter.java:97) 在 org.milyn.delivery.sax.SmooksSAXFilter.doFilter(SmooksSAXFilter.java:64) 在org.milyn.Smooks._filter (Smooks.java:526)at org.milyn.Smooks.filterSource(Smooks.java:482)at org.milyn.Smooks.filterSource(Smooks.java:456)at org.milyn.edi.unedifact.d97a .D97AInterchangeFactory.fromUNEdifact在 org.milyn.edi.unedifact.d97a.D97AInterchangeFactory.fromUNEdifact(D97AInterchangeFactory.java:40)(D97AInterchangeFactory.java:58) 在com.ibm.gpohub.edi.common.SmooksSample.main( SmooksSample.java:18) 引起:org.milyn.edisax.EDIParseException:EDI消息处理 失败[ORDRSP] [D:97A:UN]。段[FTX],字段4(TEXT_LITERAL), 组件1(Free_text _-_-1)预计包含一个值。目前 处 org.milyn.edisax.EDIParser.mapField(EDIParser.java:636)段号6. org.milyn.edisax.EDIParser.mapComponent(EDIParser.java:687)在 org.milyn.edisax .EDIParser.mapFields(EDIParser.java:606)在 org.milyn.edisax.EDIParser.mapSegment(EDIParser.java:564)在 org.milyn.edisax.EDIParser.mapSegments(EDIParser.java:535)在 组织.milyn.edisax.EDIParser.mapSegments(EDIParser.java:453)at org.milyn.edisax.EDIParser.parse(EDIParser.java:428)at org.milyn.edisax.EDIParser.parse(EDIParser.java:410 )at org.milyn.edisax.unedifact.handlers.UNHHandler.process(UNHHandler.java:97) at org.milyn.edisax.unedif act.handlers.UNGHandler.process(UNGHandler.java:58) 在 org.milyn.edisax.unedifact.handlers.UNBHandler.process(UNBHandler.java:75) 在 org.milyn.edisax.unedifact.UNEdifactInterchangeParser。解析(UNEdifactInterchangeParser.java:113) at org.milyn.smooks.edi.unedifact.UNEdifactReader.parse(UNEdifactReader.java:75) at org.milyn.delivery.sax.SAXParser.parse(SAXParser.java:76 )在 org.milyn.delivery.sax.SmooksSAXFilter.doFilter(SmooksSAXFilter.java:86) ... 7更

这里是代码片段:

D97AInterchangeFactory d97InterChangeFactory = (D97AInterchangeFactory)SmooksFactoryImpl.D97A_FACTORY.getInstance(); 
      InputStream ediSource = new FileInputStream("C:\\EDIFACT_MSG.txt"); 
      UNEdifactInterchange interchange = d97InterChangeFactory.fromUNEdifact(ediSource); 
     if(interchange instanceof UNEdifactInterchange41){ 
      List<UNEdifactMessage41> messages = ((UNEdifactInterchange41) interchange).getMessages(); 
      for(UNEdifactMessage41 msg:messages){ 
       System.out.println(msg.toString()); 
      } 
     } 

EDIMessage:

UNA:+? UNB + UNOC:3 + 662424795TEST:16 + IBMEDIID:ZZ + 160330:1416 + IG-62779496 UNG + ORDRSP + 662424795TEST:16 + IBMEDIID:ZZ + 160330:1420 + FG-34160863 + UN + D:97A UNH + 80534414 + ORDRSP:D:97A:UN BGM + 231 + 20160330 + 4 DTM + 69:20150501150000UTC +12:304 FTX + SSR +++:空白FTX + AAR ++ ST FTX + COI +++ CLW FTX + PRI ++ 8 FTX + DEL ++ 06 FTX + CUR +++将所有项目合并为一个 box FTX + DIN +++在发货前打电话给客户 FTX + PRD +++ 1:1:PC01 FTX + AAP +++ 900:接受RFF + PC:20AMS67000 RFF + SE:PC01K33E RFF + SZ:ND RFF + ABO:Y RFF + CO:IBM1234501 DTM + 4:20150501010101UTC?+12:304 RFF + ACW:CASE_12345 RFF + ADG:Y RFF + ACH:Y RFF + ZOD:order_desk01 RFF + ZSD:IBM RFF + ZPD:30006672 RFF + ZCS:空白 RFF + ZZZ NAD + SE + 300IBM NAD + BY + US00000001 ++可口可乐:CA + 9/F:841 WEBSTER ST:压力3:空白+旧金山++ 94117 +美国CTA + PD +:约旦 Surzyn [email protected]: EM COM + 6508624654:TE NAD + OY + US00000001 ++ IBM 现场服务:CA + 9/F:900 WEBSTER ST:压力3:空白+ SAN FRANCISCO ++ 94117 +美国CTA + CR +:Will Smith COM + @ ibm.com:EM COM + 6508624654:TE LIN + 10 PIA + 5 + 04X6076 IMD + F ++ ::: KEYBOARD NetVista 键盘(USB)数量+ 21:1:EA DTM + 69:20160610120000UTC?+12:304 FTX + OSI +++ INW FTX + LIN +++ ZSP1 FTX + AAP +++ 900:接受FTX + ZCT +++ STO从 DC到FSL RFF + ZSB:01 RFF + ZRO:Y RFF + ZOR:键盘很好条件 RFF + ZST:SOFT UNS + S UNT + 50 + 80534414 UNE + 1 + FG-34160863 UNZ + 1 + IG-62779496

任何人都可以指导我,我哪里做错了吗? 在此先感谢。

回答

0

这是因为EDIFACT消息格式不正确。在我得到正确的EDIFACT消息后解决,如下所示。希望任何遇到类似问题的人都可以帮助解决。 - 感谢

UNA:+。? ' UNB + UNOC:3 + IBM:ZZZ + 662424795TEST:16 + 160330:1416 + 00000016086706 ++++ 1' UNG + ORDRSP + IBM:ZZZ + 662424795TEST:16 + 160330:1420 + 00000000160867 + UN + D: 97A' UNH + 1 + ORDRSP:D:97A:UN'BGM + 231 + 20160330 + 4' DTM + 69:20160501150000UTC?+12:304'FTX + AAR ++ ER'FTX + SSR +++ N: AM' FTX + COI +++ CLW'FTX + PRI ++ 8'FTX + DEL ++ 04'FTX + CUR +++将所有项目打包到 一盒'FTX + DIN +++打给客户在交货前' FTX + PRD +++ IBMDECK001 :: PC01'FTX + AAP +++ 900:接受'RFF + PC:20AMS67000' RFF + SE:PC01K33E'RFF + SZ:ND'RFF + ABO:N' RFF + CO:IBM1234501' RFF + ACW:IBMCASE12301'DTM + 4:20150501000000UTC?+12:304' NAD + SE + 30006672 ++ 3100001'NAD + BY + US00000001 ++ CA:NEC Personal Computers,Ltd. + 9/F:841 WE BSTER ST:stress 3 + SAN FRANCISCO ++ 941171717 + US'CTA + PD +:Jordan Surzyn'[email protected]:EM' COM + 6508624654:TE'NAD + OY + US00000001 ++ CA:NEC Personal计算机, Ltd. + 9楼:841 WEBSTER ST:压力3 +旧金山++ 941171717 +美国' CTA + CR +:Jordan Surzyn'[email protected]:EM'COM + 6508624654:TE' LIN + 20 +++ 1:10'PIA + 5 + 04X6076'IMD + F ++ ::: KEYBOARD NetVista Keyboard (USB)'QTY + 21:1:EA'DTM + 69:20160610120000UTC?+12:304'FTX + LIN +++ ZSP1' FTX + AAP +++ 900:Accpet'FTX + OSI +++ INW'FTX + BSC+++ KEYBOARD in good condition'RFF + SE:Y'NAD + OY + 01 + SOFT'UNS + S'UNT + 41 + 1' UNE + 1 + 00000000160867'UNZ + 1 + 00000016086706'

+1

是的,EDIFACT默认段结束符是'字符,在UNA段中指定。 – MikeRalphson