添加链接
link管理
链接快照平台
  • 输入网页链接,自动生成快照
  • 标签化管理网页链接
Status:
Closed
Priority:
High
Category:
-
Sprint/Milestone:
-
Start date:
2019-08-20
Due date:
% Done:

0%

Estimated time:
Legacy ID :
Applies to branch :
Fix Committed on Branch :
Fixed in Maintenance Release :
Platforms :

SXXP0003: Error reported by XML parser: Content is not allowed in prolog.

I am getting this error in the production environment while transforming from one xml to another using xslt 2.0. However, it is working fine when I run the same through development and quality assurance environment.

  • No code change has been made to production.
  • Using WebSphere 8.5.5 + Saxon 9 Enterprise Edition for all the 3 environments
  • attaching input xml file along with the xslt file for reference

    **** URGENT - HIGH HIGH HIGH PRIORITY *****

    Files

    Download all files
    Copied from Saxon - Support #4288 : SXXP0003: Error reported by XML parser: Content is not allowed in prolog. Duplicate Michael Kay 2019-08-20

    Actions

    Issue # Delay: days Cancel

    The one thing we can say for certain is that there isn't enough information here to solve it.

    As the message says, SXXP0003 is an error reported to Saxon by the XML parser. The message "Content not allowed in Prolog" is produced by Xerces under a wide variety of conditions: it basically means Xerces tried reading the XML file, looked to see if it starts with "<", and found that not to be the case. It can mean the file is empty, or there's a blank line at the start, or the file isn't XML at all, or there's an unexpected byte order mark at the start, or the parser is configured to expect a different encoding.

    It's certainly nothing to do with the stylesheet. There's nothing wrong with the XML you are showing us, but it could be because, for some reason, this isn't the XML your application is actually reading. It might be useful for us to check the Java code that invokes the XSLT processor. My guess would be that it's some kind of configuration issue: unfortunately those are very hard to solve without hands-on access to the machine.

    The fact that it works in one environment and not another gives one line of attack for diagnosis: work out what's different between the two environments. Check versions of Saxon and Java and in particular check what XML parser is being used. Consider instantiating the XML parser yourself in the application rather than leaving Saxon/JAXP to instantiate it (by supplying a SAXSource with an initialized XMLReader, rather than a StreamSource).

    It's worth checking that it's not a multithreading issue. Common errors are (a) to reuse the JAXP Transformer object in multiple threads, and (b) to use a DOM Document in multiple threads.

    I note that the file TEST081919.xml that you posted starts with the octets ef bb bf 3c 3f 78 - that is, it's UTF-8 with a byte order mark. Most modern XML parsers will accept this, but there may be older XML parsers that don't - see for example https://community.boomi.com/s/article/erroronline1contentisnotallowedinprolog

    This suggests that you might be able to make progress by either (a) changing which XML parser is used in your production environment, or (b) saving the XML file without a BOM at the start.