无法将名称 'X' 解析为 (n) 'type definition' 组件
Cannot resolve the name 'X' to a(n) 'type definition' component
有很多帖子与此标题相同。我看过很多,但是他们的情况好像和我的不一样。
我有一个 Java 应用程序,由 XML 文件配置在 run-time。有一个相应的 XML 模式定义了 XML 的结构。该模式导入其他模式以使用它们定义的类型定义。应用程序读取模式和配置文件并将 XML 加载为 Java objects.
该应用程序是使用 Apache Maven 构建的,maven-jaxb2-plugin 用于将模式定义转换为 Java 类,因此应用程序可以获取 XML 配置信息.一切都成功构建,据我所知,生成的 XJC 类 是正确的并且位于正确的位置。
当我尝试执行应用程序时,我 运行 遇到了一个问题,它首先读取 XML 并将其加载为 Java objects。下面是一个异常示例。
[2018-08-09 10:31:05.056] ERROR: common.ConfigLoader:121 - Exception:
org.xml.sax.SAXParseException; lineNumber: 291; columnNumber: 80; src-resolve: Cannot resolve the name 'sc:ExpectedDataFormatEnum' to a(n) 'type definition' component.
at com.sun.org.apache.xerces.internal.util.ErrorHandlerWrapper.createSAXParseException(ErrorHandlerWrapper.java:198)
at com.sun.org.apache.xerces.internal.util.ErrorHandlerWrapper.error(ErrorHandlerWrapper.java:134)
at com.sun.org.apache.xerces.internal.impl.XMLErrorReporter.reportError(XMLErrorReporter.java:437)
at com.sun.org.apache.xerces.internal.impl.xs.traversers.XSDHandler.reportSchemaErr(XSDHandler.java:4162)
at com.sun.org.apache.xerces.internal.impl.xs.traversers.XSDHandler.reportSchemaError(XSDHandler.java:4145)
at com.sun.org.apache.xerces.internal.impl.xs.traversers.XSDHandler.getGlobalDecl(XSDHandler.java:1678)
at com.sun.org.apache.xerces.internal.impl.xs.traversers.XSDElementTraverser.traverseNamedElement(XSDElementTraverser.java:405)
at com.sun.org.apache.xerces.internal.impl.xs.traversers.XSDElementTraverser.traverseLocal(XSDElementTraverser.java:194)
at com.sun.org.apache.xerces.internal.impl.xs.traversers.XSDHandler.traverseLocalElements(XSDHandler.java:3618)
at com.sun.org.apache.xerces.internal.impl.xs.traversers.XSDHandler.parseSchema(XSDHandler.java:633)
at com.sun.org.apache.xerces.internal.impl.xs.XMLSchemaLoader.loadSchema(XMLSchemaLoader.java:617)
at com.sun.org.apache.xerces.internal.impl.xs.XMLSchemaLoader.loadGrammar(XMLSchemaLoader.java:575)
at com.sun.org.apache.xerces.internal.impl.xs.XMLSchemaLoader.loadGrammar(XMLSchemaLoader.java:541)
at com.sun.org.apache.xerces.internal.jaxp.validation.XMLSchemaFactory.newSchema(XMLSchemaFactory.java:252)
at javax.xml.validation.SchemaFactory.newSchema(SchemaFactory.java:627)
at {removed}.ConfigLoader.load(ConfigLoader.java:91)
at {removed}.Launcher.main(Launcher.java:121)
[2018-08-09 10:31:05.058] ERROR: wf.Launcher:122 - Unable to load configuration file
我怀疑问题与导入模式在 run-time 的 referenced/resolved 相关。我使用 XML 目录(对我来说是一个新概念)在构建期间解析模式位置。我需要类似的东西来在 运行 时间解析位置吗?
对于上下文,这里是相关文件的片段。
由应用程序架构导入的架构 (security-common.xsd):
<xs:schema xmlns:xs="http://www.w3.org/2001/XMLSchema" targetNamespace="security_common"
xmlns:sc="security_common" elementFormDefault="qualified" attributeFormDefault="unqualified">
<xs:simpleType name="TypeList">
<xs:list itemType="xs:string" />
</xs:simpleType>
<xs:simpleType name="ExpectedDataFormatEnum">
<xs:restriction base="xs:string">
<xs:enumeration value="STRING" />
<xs:enumeration value="BYTE_ARRAY" />
</xs:restriction>
</xs:simpleType>
</xs:schema>
使用上述架构的应用程序架构 (config-schema.xsd):
<xs:schema xmlns:xs="http://www.w3.org/2001/XMLSchema" targetNamespace="injector"
xmlns:inj="injector" xmlns:sc="security_common" xmlns:camel="camel_config"
elementFormDefault="qualified" attributeFormDefault="unqualified">
<xs:import namespace="security_common" />
<xs:import namespace="camel_config" />
...
<xs:complexType name="WireCaptureConfig">
<xs:sequence>
<xs:element name="expected-data-format" type="sc:ExpectedDataFormatEnum" />
...
</xs:sequence>
</xs:complexType>
...
</xs:schema>
XML目录文件:
PUBLIC "security_common" "maven:{removed}:security-common:jar::!/config/security-common.xsd"
PUBLIC "camel_config" "maven:{removed}:security-common:jar::!/config/camel-config.xsd"
我的理解是目录文件将模式命名空间映射到 Maven 工件,它表示模式 imported/referenced。这似乎有点黑魔法,但确实有效。
抛出的异常似乎表明应用程序无法 "see" 导入的架构定义。根据所描述的内容,是否有解决此问题的方法?如果需要提供其他信息,请告诉我,我会尽力而为。
您怀疑您也必须在运行时 Java 代码中为您的 XML 目录提供住宿是对的。
参见 Using an XML Catalog with a Java library that uses JAXP internally for details on how to use a CatalogResolver (or org.apache.xml.resolver.tools.CatalogResolver)。
另请注意,通过将 XSD 放置在 URI 可访问的位置1 并添加 @schemaLocation
属性,可以确定所有其他内容与您的 XSD 一致给你的xs:imports
。许多 XML 目录实施的诊断消息对于追踪问题而言并不理想。
1见How to reference a local XML Schema file correctly?
有很多帖子与此标题相同。我看过很多,但是他们的情况好像和我的不一样。
我有一个 Java 应用程序,由 XML 文件配置在 run-time。有一个相应的 XML 模式定义了 XML 的结构。该模式导入其他模式以使用它们定义的类型定义。应用程序读取模式和配置文件并将 XML 加载为 Java objects.
该应用程序是使用 Apache Maven 构建的,maven-jaxb2-plugin 用于将模式定义转换为 Java 类,因此应用程序可以获取 XML 配置信息.一切都成功构建,据我所知,生成的 XJC 类 是正确的并且位于正确的位置。
当我尝试执行应用程序时,我 运行 遇到了一个问题,它首先读取 XML 并将其加载为 Java objects。下面是一个异常示例。
[2018-08-09 10:31:05.056] ERROR: common.ConfigLoader:121 - Exception:
org.xml.sax.SAXParseException; lineNumber: 291; columnNumber: 80; src-resolve: Cannot resolve the name 'sc:ExpectedDataFormatEnum' to a(n) 'type definition' component.
at com.sun.org.apache.xerces.internal.util.ErrorHandlerWrapper.createSAXParseException(ErrorHandlerWrapper.java:198)
at com.sun.org.apache.xerces.internal.util.ErrorHandlerWrapper.error(ErrorHandlerWrapper.java:134)
at com.sun.org.apache.xerces.internal.impl.XMLErrorReporter.reportError(XMLErrorReporter.java:437)
at com.sun.org.apache.xerces.internal.impl.xs.traversers.XSDHandler.reportSchemaErr(XSDHandler.java:4162)
at com.sun.org.apache.xerces.internal.impl.xs.traversers.XSDHandler.reportSchemaError(XSDHandler.java:4145)
at com.sun.org.apache.xerces.internal.impl.xs.traversers.XSDHandler.getGlobalDecl(XSDHandler.java:1678)
at com.sun.org.apache.xerces.internal.impl.xs.traversers.XSDElementTraverser.traverseNamedElement(XSDElementTraverser.java:405)
at com.sun.org.apache.xerces.internal.impl.xs.traversers.XSDElementTraverser.traverseLocal(XSDElementTraverser.java:194)
at com.sun.org.apache.xerces.internal.impl.xs.traversers.XSDHandler.traverseLocalElements(XSDHandler.java:3618)
at com.sun.org.apache.xerces.internal.impl.xs.traversers.XSDHandler.parseSchema(XSDHandler.java:633)
at com.sun.org.apache.xerces.internal.impl.xs.XMLSchemaLoader.loadSchema(XMLSchemaLoader.java:617)
at com.sun.org.apache.xerces.internal.impl.xs.XMLSchemaLoader.loadGrammar(XMLSchemaLoader.java:575)
at com.sun.org.apache.xerces.internal.impl.xs.XMLSchemaLoader.loadGrammar(XMLSchemaLoader.java:541)
at com.sun.org.apache.xerces.internal.jaxp.validation.XMLSchemaFactory.newSchema(XMLSchemaFactory.java:252)
at javax.xml.validation.SchemaFactory.newSchema(SchemaFactory.java:627)
at {removed}.ConfigLoader.load(ConfigLoader.java:91)
at {removed}.Launcher.main(Launcher.java:121)
[2018-08-09 10:31:05.058] ERROR: wf.Launcher:122 - Unable to load configuration file
我怀疑问题与导入模式在 run-time 的 referenced/resolved 相关。我使用 XML 目录(对我来说是一个新概念)在构建期间解析模式位置。我需要类似的东西来在 运行 时间解析位置吗?
对于上下文,这里是相关文件的片段。
由应用程序架构导入的架构 (security-common.xsd):
<xs:schema xmlns:xs="http://www.w3.org/2001/XMLSchema" targetNamespace="security_common"
xmlns:sc="security_common" elementFormDefault="qualified" attributeFormDefault="unqualified">
<xs:simpleType name="TypeList">
<xs:list itemType="xs:string" />
</xs:simpleType>
<xs:simpleType name="ExpectedDataFormatEnum">
<xs:restriction base="xs:string">
<xs:enumeration value="STRING" />
<xs:enumeration value="BYTE_ARRAY" />
</xs:restriction>
</xs:simpleType>
</xs:schema>
使用上述架构的应用程序架构 (config-schema.xsd):
<xs:schema xmlns:xs="http://www.w3.org/2001/XMLSchema" targetNamespace="injector"
xmlns:inj="injector" xmlns:sc="security_common" xmlns:camel="camel_config"
elementFormDefault="qualified" attributeFormDefault="unqualified">
<xs:import namespace="security_common" />
<xs:import namespace="camel_config" />
...
<xs:complexType name="WireCaptureConfig">
<xs:sequence>
<xs:element name="expected-data-format" type="sc:ExpectedDataFormatEnum" />
...
</xs:sequence>
</xs:complexType>
...
</xs:schema>
XML目录文件:
PUBLIC "security_common" "maven:{removed}:security-common:jar::!/config/security-common.xsd"
PUBLIC "camel_config" "maven:{removed}:security-common:jar::!/config/camel-config.xsd"
我的理解是目录文件将模式命名空间映射到 Maven 工件,它表示模式 imported/referenced。这似乎有点黑魔法,但确实有效。
抛出的异常似乎表明应用程序无法 "see" 导入的架构定义。根据所描述的内容,是否有解决此问题的方法?如果需要提供其他信息,请告诉我,我会尽力而为。
您怀疑您也必须在运行时 Java 代码中为您的 XML 目录提供住宿是对的。
参见 Using an XML Catalog with a Java library that uses JAXP internally for details on how to use a CatalogResolver (or org.apache.xml.resolver.tools.CatalogResolver)。
另请注意,通过将 XSD 放置在 URI 可访问的位置1 并添加 @schemaLocation
属性,可以确定所有其他内容与您的 XSD 一致给你的xs:imports
。许多 XML 目录实施的诊断消息对于追踪问题而言并不理想。
1见How to reference a local XML Schema file correctly?