3

这个问题看起来很简单,但我找不到合适的位置在 WSDL 文档中设置其定义的版本。

目标是能够很容易地看到它什么时候过时,我将来什么时候更新它。

我要把它设置为1.0。如果将来我向它添加一个新操作,我将它设置为 1.1。然后,如果有人拥有 1.0 版本,很容易看到它缺少该操作定义并请求更新它。

4

1 回答 1

3

首先要意识到的是,服务的新版本可以被视为新服务。相似但不同。然后问题变为“如果服务相似,如何最大限度地减少重复”。

至于版本控制,您可以使用名称空间声明(例如targetNamespace="mynamespace/1.0")或<version>1.0</version>在(或version="1.0"属性上)用于请求/响应消息的类型的根节点中的标记)。

使用命名空间很可能意味着一种实现只能服务于一个版本的服务。如果您希望某个实现服务于版本 1.0-1.3 和另一个 1.3+,那么您可能会使用该<version/>方法(或@version),因为在这种情况下只有一个命名空间。然后,实现可以在内部根据 的值决定是处理还是拒绝<version/>

在更加混合的服务环境中,您可以使用该<version/>方法创建一个代理实现,该实现中继到使用该targetNamespace方法的服务。最好还是使用 UDDI,如果您有一个可以使用的话。

请考虑您的更改的向后兼容性。正如您所建议的,添加操作是完全向后兼容的。如果你有一个 1.0 版本的客户端 X,并向你的服务器(现在是 1.1)添加一个操作,X 仍然可以调用服务器,因为 X 知道的所有操作仍然可用。(前提是您没有更改命名空间以反映(使用<version/>.)的版本。接口的(不存在)向后兼容性通常反映在更改的主要版本号(例如 1.1 -> 2.0)中,这可能会导致您意识到您可以对命名空间进行重大更改,并使用<version/>标记进行次要更改。

玩得开心,这是有趣的事情!

于 2013-01-15T07:39:04.670 回答