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) org.milyn.Smooks.filterSource(Smooks.java:482) で org.milyn.Smooks.filterSource(Smooks.java:456) で org.milyn.edi.unedifact.d97a.D97AInterchangeFactory.fromUNEDifact(D97AInterchangeFactory. java:58) org.milyn.edi.unedifact.d97a.D97AInterchangeFactory.fromUNEdifact(D97AInterchangeFactory.java:40) で 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) には値が含まれていると予想されます。現在、セグメント番号 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) org.milyn.edisax.EDIParser.parse(EDIParser.java:428) org.milyn.edisax.EDIParser.parse(EDIParser.java:410) org.milyn.edisax.unedifact .handlers.UNHHandler.process(UNHHandler.java:97) at org.milyn.edisax.unedifact.handlers.UNGHandler.process(UNGHandler.java:58) at 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メッセージ:

ウナ:+.? 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+++すべての商品を 1 つの箱に梱包する 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++Coca Cola:CA+9/F:841 WEBSTER ST:ストレス 3:ブランク​​+サンフランシスコ++94117+US CTA+PD+:ジョーダン・サージン COM+Minako@DHL.com:EM COM+6508624654:

私が間違っているところを教えてもらえますか?前もって感謝します。

4

1 に答える 1

2

不適切な EDIFACT メッセージ形式が原因でした。以下に示すように、適切な EDIFACT メッセージを取得した後に解決されました。同様の問題に直面した人がこれに役立つことを願っています。 - ありがとう

ウナ:+.? ' 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+++すべての商品を 1 つの箱に梱包する' 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+US' CTA+PD+:Jordan Surzyn'

于 2016-09-14T05:34:03.007 に答える