Java怎么用DOM Level 3的API进行XML验证

12次阅读

javadom Level 3 xml验证需显式启用:先设DocumentBuilderFactory的setValidating(true)和setNamespaceAware(true),再通过DocumentBuilder.setFeature()开启schema、dynamic等特性,最后注册ErrorHandler捕获错误。

Java怎么用DOM Level 3的API进行XML验证

Java 中使用 DOM Level 3 的 API 进行 XML 验证,核心是启用 DOMConfiguration 中的验证相关参数,并配合 DocumentBuilder 加载带 DTD 或 XML Schema 的文档。注意:Java 自带的 Xerces 实现(JDK 8+ 内置)支持 DOM Level 3 的验证功能,但需显式开启,且默认不校验。

启用 DOM Level 3 验证支持

DocumentBuilderFactory 开始,必须设置两个关键属性:

  • setValidating(true):启用 DTD 验证(基础验证)
  • setNamespaceAware(true):必须开启,否则 XML Schema 验证会失败

仅靠这两个还不够——DOM Level 3 的验证行为由 DOMConfiguration 控制,而它在 Document 创建后才可访问。因此,更可靠的方式是结合 SAX 解析器或直接配置 DocumentBuildersetFeature

用 DocumentBuilder + DOM Level 3 特性控制验证

Java 的 DocumentBuilder 支持通过 setFeature() 启用 DOM Level 3 定义的验证特性:

立即学习Java免费学习笔记(深入)”;

  • parser.setFeature("http://apache.org/xml/features/validation/schema", true); —— 启用 XML Schema 验证
  • parser.setFeature("http://apache.org/xml/features/validation/dynamic", true); —— 动态验证(如修改后重新校验)
  • parser.setFeature("http://w3.org/DOM/Level3/core", true); —— 显式声明支持 Level 3(部分老版本需要)

⚠️ 注意:setFeature 必须在 newDocumentBuilder() 之后、parse() 之前调用;若特性不被支持,会抛 ParserConfigurationException

加载并捕获验证错误

DOM Level 3 验证的错误不会静默忽略,但默认不抛异常。你需要注册 ErrorHandler 来捕获问题:

  • 实现 org.xml.sax.ErrorHandler 接口warning()error()fatalError()
  • 调用 parser.setErrorHandler(yourHandler)
  • fatalError 会中断解析,error 表示严重但可能继续(如元素缺失),warning 多为非规范建议

例如:DTD 中声明了 ,但 XML 缺少 author,会触发 error() 回调。

Schema 验证需额外指定 schemaLocation

仅开启 schema 特性还不够,XML 文档需声明 schema 位置,例如:


xsi:noNamespaceSchemaLocation=”book.xsd”>
Java DOM

或者通过 parser.setAttribute("http://apache.org/xml/properties/schema/external-noNamespaceSchemaLocation", "book.xsd") 程序化指定(适用于无内嵌声明的文档)。

基本上就这些。DOM Level 3 验证不是“自动开箱即用”,关键在显式启用特性、绑定 schema、捕获 handler —— 不复杂但容易忽略细节。

text=ZqhQzanResources