2

我有两个 xsd 文件“first.xsd”和“second.xsd”。

在 second.xsd 中,我想引用 first.xsd 中定义的元素(具有不同的命名空间)。
我的 second.xsd 看起来像:

<xs:schema ... xmlns:schema1="http://www.schema.org/schema1" targetNamespace "http://www.schema.org/schema2   ...  >
<xs:import namespace = "http://www.schema.org/schema1" schemaLocation = "first.xsd" />

<xs:element name = "complex1">
<xs:complexType>
.........
<xs:element ref="schema1:name2"/>
.........
</xs:complexType>
</xs:element>

现在我想在 first.xsd 中包含和导入 second.xsd 所以我在 first.xsd 中执行以下操作:

<xs:schema ... xmlns:schema2="http://www.schema.org/schema2" targetNamespace "http://www.schema.org/schema1  ... >
<xs:import namespace="http://www.schema.org/schema2" schemaLocation="second.xsd">
<xs:element name = "name1"/>
<xs:element name = "name2"/>
<xs:element name = "name3"/>

这是正确的方法吗,因为我无法成功验证架构。
由于某些循环命名空间包含,这是一个问题吗?
我正在使用氧气 xml 开发人员来验证架构文件,并且我的 first.xsd 验证后说:
E[Xerces] src-resolve:无法将名称解析为 a(n) 类型定义组件。(第二个.xsd)

但是,如果我单独验证 second.xsd 文件,它会说架构有效。

在我的实际情况中,我有一个非常复杂的场景,因此我将其归结为一个简单的示例,如上所示。
有人可以帮忙吗。

4

1 回答 1

3

拥有这种循环依赖是完全有效的(尽管值得商榷);您的架构集无法验证的原因不可能是它;您必须检查架构处理器生成的错误并尝试理解其中的每一个。人们普遍认为,最好从第一条错误消息开始。

您的代码段无效,因为您引用了element2未在schema1中列出的(在 second.xsd 中) 。这是一种无法通过验证的东西,因此请关注它们。

如果您需要帮助以了解真正的问题是什么,请首先使用实际的错误消息更新您的帖子。

于 2012-05-25T16:52:29.140 回答