SAXParseException:元素类型“CountryNamecode”必须后跟属性规范,“>”或“/>”

时间:2012-02-27 15:05:49

标签: java xml sax jaxp

好的,这似乎是一个常见的错误信息,但我从几个角度看了这个,我很难过。

我的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。除非有一些显而易见的东西我缺席

1 个答案:

答案 0 :(得分:1)

我准备打赌问题出在基础数据流代码中。

要支持我的理论,请打开原始数据文件,将光标移动到CountryNamecode之间的空格,并找到确定文件中该空格字符的确切偏移量的方法。它可能是1024的精确倍数,可能是4096或8192。

然后查看您用于提供SAX解析器的InputSourceReader代码。它可能看起来像:

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))是什么破坏了数据。