我有一个java程序,使用xerces API解析XML文档.
我的解析类扩展了org.apache.xerces.parsers.XMLDocumentParser,重载了startElement,endElement,characters方法.
由于它是一个手工编写的复杂XML文档(主要是某种配置元素),xsd或dtd的经典验证是不够的,我必须向用户返回XML文档无效.
但我无法实现的一件事是在错误消息中添加有关当前正在解析的行号(以及为什么不是列号)的信息以及错误发生的位置.
我认为这是可能的,因为当XML文档不是XML有效时,解析器生成的异常(org.apache.xerces.xni.parser.XMLParseException)包含这些信息.
解决方法:
我从未尝试使用xerces,但SAX解析器可以存储SAX Locator,您可以在解析文档时(或在异常之后)从中获取行号和列号.
看起来XMLDocumentParser可能会做同样的事情.它的父类AbstractXMLDocumentParser有一个startDocument方法,它传递一个XMLLocator参数.如果重写此方法,则可以保存XMLLocator并使用其getLineNumber和getColumnNumber方法.