2

我有一个问题,我正在使用 maven war 插件构建战争并使用 bnd 插件覆盖它,如将 OSGi 元数据添加到现有项目中所述,而不更改打包类型。 该项目定义了以下依赖项:

    <dependency>
        <groupId>com.sun.jersey</groupId>
        <artifactId>jersey-server</artifactId>
        <version>1.12</version>
    </dependency>

当我运行构建时,它会在 MANIFEST.MF 中生成以下条目

Import-Package: .., javax.ws.rs.core,  ..

一旦我将版本更改为 1.13 或更高版本,Import-Package 条目就会变为:

Import-Package: .., javax.ws.rs;version="[1.1,2)", ..

这对我来说是一个真正的问题,因为我的目标中有 javax.ws.rs.javax.ws.rs-api_2.0.0.m16。这将解决不需要版本的情况下的导入,但在存在范围限制时停止这样做。

所以,我的一般问题是:bnd 如何决定版本范围?两个次要版本之间发生了一些变化,使其从无版本限制变为特定范围,因此我认为了解 bnd 如何做出该决定将有助于我发现这个特定问题是什么。

4

1 回答 1

9

Bnd 使用 OSGi 语义版本控制——请阅读白皮书(PDF 链接)。

首先,bnd 计算出在构建时使用了哪个版本的包。您在构建路径上拥有的 JSR311 API Jar 必须包含版本化Export-Package语句,这很好,并且该版本必须是 1.1。因此,您的包可以使用的该软件包的最低版本是 1.1。

语义版本控制表示主要(即第一个)段增加以指示所有用户的重大更改。因此,您的捆绑包将与包的 2.* 版本不兼容javax.ws.rs。所以 bnd 生成的范围最多但不包括 2... 即[1.1,2).

我不明白为什么这会给你带来问题。你说你想部署一个调用javax.ws.rs.javax.ws.rs-api_2.0.0.m16到你的目标的包,但这看起来像一个文件名。你检查javax.ws.rs过bundle里面的包是不是版本2吗?如果它仍然是版本 1.* 那么你可以使用它...如果它是版本 2.* 那么这意味着包包含重大更改,所以你不应该使用它。最后,如果包的版本是 2.* 但它并不是真正的重大更改,那么创建该包的人已经搞砸了,他们需要回去阅读我链接到的 PDF。

于 2013-05-17T01:02:23.920 回答