2

我正在尝试读取 EDI 消息并将其转换为 Java 对象,但我以以下异常结束。

线程“主”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(D97AInterchangeFactory. java:58) at org.milyn.edi.unedifact.d97a.D97AInterchangeFactory.fromUNEdifact(D97AInterchangeFactory.java:40) at 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.mapComponent(EDIParser.java:687) 的 org.milyn.edisax.EDIParser.mapField(EDIParser.java:636) 的第 6 段。 (EDIParser.java:606) 在 org.milyn.edisax.EDIParser.mapSegment(EDIParser.java:564) 在 org.milyn.edisax.EDIParser.mapSegments(EDIParser.java:535) 在 org.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) 在 org.milyn.edisax.unedifact.handlers.UNGHandler.process(UNGHandler.java:58) 在 org.milyn.edisax.unedifact.handlers.UNBHandler.process(UNBHandler .java:

这是代码片段:

 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());
            }
        }

EDI消息:

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+++将所有物品打包成一个盒子 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+30001234++IBM NAD+BY+US00000001++可口可乐:CA+9/F:841 WEBSTER ST:压力3:空白+SAN FRANCISCO++94117+US CTA+PD+:Jordan Surzyn COM+Minako@DHL.com:EM COM+6508624654:

谁能指导我,我在哪里做错了?提前致谢。

4

1 回答 1

2

这是因为不正确的 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:accept' 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 WEBSTER ST:stress 3 +旧金山++941171717+美国'CTA+PD+:Jordan Surzyn'

于 2016-09-14T05:34:03.007 回答