微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

java – 使用Xerces解析XML文档时是否可以获取当前行号?

我有一个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方法.

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。