我的XML文件是
<?xml version="1.0" encoding="ISO-8859-1"?>
<T0020
xsi:schemaLocation="http://www.safersys.org/namespaces/T0020V1 T0020V1.xsd"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns="http://www.safersys.org/namespaces/T0020V1">
<INTERFACE>
<NAME>SAFER</NAME>
<VERSION>04.02</VERSION>
</INTERFACE>
<TRANSACTION>
<VERSION>01.00</VERSION>
<OPERATION>REPLACE</OPERATION>
<DATE_TIME>2009-09-01T00:00:00</DATE_TIME>
<TZ>CT</TZ>
</TRANSACTION>
<IRP_ACCOUNT>
<IRP_CARRIER_ID_NUMBER>564182</IRP_CARRIER_ID_NUMBER>
<IRP_BASE_COUNTRY>US</IRP_BASE_COUNTRY>
<IRP_BASE_STATE>AR</IRP_BASE_STATE>
<IRP_ACCOUNT_NUMBER>67432</IRP_ACCOUNT_NUMBER>
<IRP_ACCOUNT_TYPE>I</IRP_ACCOUNT_TYPE>
<IRP_STATUS_CODE>100</IRP_STATUS_CODE>
<IRP_STATUS_DATE>2008-02-01</IRP_STATUS_DATE>
<IRP_UPDATE_DATE>2009-06-18</IRP_UPDATE_DATE>
<IRP_NAME>
<NAME_TYPE>LG</NAME_TYPE>
<NAME>LARRY SHADDON</NAME>
<IRP_ADDRESS>
<ADDRESS_TYPE>PH</ADDRESS_TYPE>
<STREET_LINE_1>10291 HWY 124</STREET_LINE_1>
<STREET_LINE_2/>
<CITY>RUSSELLVILLE</CITY>
<STATE>AR</STATE>
<ZIP_CODE>72802</ZIP_CODE>
<COUNTY>POPE</COUNTY>
<COLONIA/>
<COUNTRY>US</COUNTRY>
</IRP_ADDRESS>
<IRP_ADDRESS>
<ADDRESS_TYPE>MA</ADDRESS_TYPE>
<STREET_LINE_1>10291 HWY124</STREET_LINE_1>
<STREET_LINE_2/>
<CITY>RUSSELLVILLE</CITY>
<STATE>AR</STATE>
<ZIP_CODE>72802</ZIP_CODE>
<COUNTY>POPE</COUNTY>
<COLONIA/>
<COUNTRY>US</COUNTRY>
</IRP_ADDRESS>
</IRP_NAME>
</IRP_ACCOUNT>
</T0020>
我正在使用以下XSLT将我的xml文件拆分为多个xml文件。
<xsl:stylesheet xmlns:xsl="http://www.w3.org/1999/XSL/Transform" xmlns:t="http://www.safersys.org/namespaces/T0020V1" version="2.0">
<xsl:output method="xml" indent="yes" name="xml" />
<xsl:variable name="accounts" select="t:T0020/t:IRP_ACCOUNT" />
<xsl:variable name="size" select="30" />
<xsl:template match="/">
<xsl:for-each select="$accounts[position() mod $size = 1]">
<xsl:variable name="filename" select="resolve-uri(concat('output/',position(),'.xml'))" />
<xsl:result-document href="{$filename}" method="xml">
<T0020>
<xsl:for-each select=". | following-sibling::t:IRP_ACCOUNT[position() < $size]">
<xsl:copy-of select="." />
</xsl:for-each>
</T0020>
</xsl:result-document>
</xsl:for-each>
</xsl:template>
</xsl:stylesheet>
它在Sample Java Apllication中运行良好,但是当我尝试在基于Spring的应用程序中使用它时,它会出现以下错误。
Error on line 1 column 1 of T0020:
SXXP0003: Error reported by XML parser: Content is not allowed in prolog.
我不知道出了什么问题?请帮我。在此先感谢。
答案 0 :(得分:4)
您的XML以UTF-8(0xEF,0xBB,0xBF)中的字节顺序标记开头,这是不可见的。尝试使用十六进制编辑器打开文件并查看。
Windows下的许多文本编辑器喜欢在UTF-8编码文本的开头插入此文件,尽管事实上UTF-8实际上需要字节顺序标记,因为字节顺序在UTF-8中已经很好地定义了。
Java的XML解析器将全部阻塞在您正在看到的错误消息的BOM上。您需要删除BOM,或者为您的InputStream编写一个包装器,您正在处理XML解析器以便在解析时为您执行此操作。
答案 1 :(得分:1)
在XML数据开始之前,文档中有一些内容,可能是猜测的空格(这是我以前见过的地方)。
prolog是开头标记之前的文档的一部分,具有类似<?
和<!
的标记结构。这些标签之间也可能有一些字符/空格。 Prolog和有效内容在tiztag.com上解释。
也许会发布一个非人格化的XML数据示例?
答案 2 :(得分:0)
如果您尝试两次处理内容,也可以获得此功能。 (这在春天很容易做到。)在这种情况下,你的XML没有任何问题。这种情况似乎很可能是因为示例应用程序正常工作,但引入spring会导致问题。
答案 3 :(得分:0)
就我而言,encoding="UTF-16"
导致了此问题。当我将其更改为UTF-8
时,它就解决了。