2

OK、これは一般的なエラーメッセージのようですが、私はこれをいくつかの角度から見て、困惑しています。

私のXML(完全なファイルは巨大なので、誰かが私にもっと必要な方法/理由を教えてくれない限り、関連していると思われる領域に限定します):

<?xml version="1.0" encoding="utf-8"?>
<MyXML date="201112102200" type="daily">
    <CountryList>
        <CountryName code="AARCT" name="Antarctica" IsTerritory="True"/>
        <CountryName code="ABKHAZ" name="Abkhazia" IsTerritory="True"/>

        <!-- ... -->

        <CountryName code="VCAN" name="Vatican City" IsTerritory="False" ProfileURL="vatican city.doc"/>
        <CountryName code="VEN" name="Venezuela" IsTerritory="False" ProfileURL="venezuela.doc"/>
        <CountryName code="VI" name="US Virgin Islands" IsTerritory="True"/>
        <CountryName code="VIETN" name="Vietnam" IsTerritory="False" ProfileURL="vietnam.doc"/>
        <CountryName code="WALLIS" name="Wallis and Futuna Islands" IsTerritory="True"/>
        <CountryName code="WSOMOA" name="Samoa" IsTerritory="False" ProfileURL="samoa.doc"/>
        <CountryName code="YEMAR" name="Yemen" IsTerritory="False" ProfileURL="yemen.doc"/>
        <CountryName code="YUG" name="Serbia" IsTerritory="False" ProfileURL="serbia.doc"/>
        <CountryName code="ZAIRE" name="Democratic Republic of the Congo" IsTerritory="False" ProfileURL="democratic republic of the congo.doc"/>
        <CountryName code="ZAMBIA" name="Zambia" IsTerritory="False" ProfileURL="zambia.doc"/>
        <CountryName code="ZIMBAB" name="Zimbabwe" IsTerritory="False" ProfileURL="zimbabwe.doc"/>
    </CountryList>

    <!-- ... -->

</MyXML>

したがって、エラーは次のとおりです。

org.xml.sax.SAXParseException: Element type "CountryNamecode" must be followed by either attribute specifications, ">" or "/>".
    at com.sun.org.apache.xerces.internal.parsers.AbstractSAXParser.parse(AbstractSAXParser.java:1231)
    at com.foo.bar.Baz.<init>(Baz.java:38)
    at com.foo.bar.BazTest.testRecordCounts(BazTest.java:69)
    at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
    at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:39)
    at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:25)
    at java.lang.reflect.Method.invoke(Method.java:597)
    at org.junit.runners.model.FrameworkMethod$1.runReflectiveCall(FrameworkMethod.java:44)
    at org.junit.internal.runners.model.ReflectiveCallable.run(ReflectiveCallable.java:15)
    at org.junit.runners.model.FrameworkMethod.invokeExplosively(FrameworkMethod.java:41)
    at org.junit.internal.runners.statements.InvokeMethod.evaluate(InvokeMethod.java:20)
    at org.junit.internal.runners.statements.RunBefores.evaluate(RunBefores.java:28)
    at org.junit.internal.runners.statements.RunAfters.evaluate(RunAfters.java:31)
    at org.junit.runners.BlockJUnit4ClassRunner.runChild(BlockJUnit4ClassRunner.java:76)
    at org.junit.runners.BlockJUnit4ClassRunner.runChild(BlockJUnit4ClassRunner.java:50)
    at org.junit.runners.ParentRunner$3.run(ParentRunner.java:193)
    at org.junit.runners.ParentRunner$1.schedule(ParentRunner.java:52)
    at org.junit.runners.ParentRunner.runChildren(ParentRunner.java:191)
    at org.junit.runners.ParentRunner.access$000(ParentRunner.java:42)
    at org.junit.runners.ParentRunner$2.evaluate(ParentRunner.java:184)
    at org.junit.internal.runners.statements.RunBefores.evaluate(RunBefores.java:28)
    at org.junit.internal.runners.statements.RunAfters.evaluate(RunAfters.java:31)
    at org.junit.runners.ParentRunner.run(ParentRunner.java:236)
    at org.eclipse.jdt.internal.junit4.runner.JUnit4TestReference.run(JUnit4TestReference.java:50)
    at org.eclipse.jdt.internal.junit.runner.TestExecution.run(TestExecution.java:38)
    at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.runTests(RemoteTestRunner.java:467)
    at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.runTests(RemoteTestRunner.java:683)
    at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.run(RemoteTestRunner.java:390)
    at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.main(RemoteTestRunner.java:197)

国コード「VI」の後で失敗していること、および「VIETN」エントリに問題があることを示したロギング。

したがって、「CountryNamecode」と呼ばれる不正な形式の要素はないようです。危険な文字をチェックしましたが、文字的にはかなりバニラです。STS、Oxygen、およびxmllintを使用して、ファイル全体をチェックしたときに検証されます。

これに関する助けをいただければ幸いです。

皆さん、乾杯!

編集:

XMLReader xmlReader = XMLReaderFactory.createXMLReader();
xmlReader.setContentHandler(this);
xmlReader.setErrorHandler(this);
xmlReader.parse(new InputSource(new StringReader(retriever.getContent())));

レトリバーオブジェクトはxml文字列を返します。それ以外は、InputSourceを解析して、StringReaderを渡します。明らかな何かがない限り、私は行方不明です

4

1 に答える 1

1

この問題は、基になるデータ ストリーム コードにあると断言できます。

私の理論を裏付けるために、元のデータ ファイルを開き、カーソルを と の間のスペースに移動CountryNamecode、ファイル内のそのスペース文字の正確なオフセットを決定する方法を見つけます。1024 の正確な倍数である可能性が高く、おそらく 4096 または 8192 です。

次に、SAX パーサーにフィードするために使用しているInputSourceorコードを調べます。Readerおそらく次のようになります。

sax = factory.newSAXParser();
try {
  // Here I am using an InputSource wrapping a StringReader.
  sax.parse(new InputSource(new StringReader(xml)), this);
} catch (SAXException ex) {
  log.warning("XMLParser failed on: "+xml, ex);
}

上記の代わりにnew InputSource(new StringReader(xml))使用しているものは何でも、データが破損していると思われます。

于 2012-02-27T15:33:48.413 に答える