我有一个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 定位器,在解析文档时(或者在异常之后)可以从中获取行号和列号.
它看起来似乎XMLDocumentParser
可以做同样的事情.它的父类AbstractXMLDocumentParser
有一个startDocument方法,它传递一个XMLLocator
参数.如果重写此方法,您可以保存XMLLocator
并使用其getLineNumber
和getColumnNumber
方法.