我正在为几个客户端编写Java API,并且内部会喜欢使用Spring以及它的几个功能,但我不想向客户端公开我的依赖项。
这可能吗?
因此,如果我的客户端使用不同版本的spring,它们将与我的内部Spring依赖项隔离。
如果是这样,我的spring依赖项会在我的jar内部捆绑吗?我的客户端应用程序是否需要自定义类加载器?
我听说你可以通过OSGI捆绑使用它,但我想知道这是否符合我的要求。
我的API的客户端不会启用OSGI,或者我们没有使用OSGI捆绑包的当前环境。
答案 0 :(得分:1)
这样做并不可行或不可取。你为什么要“隐藏”依赖关系?您是否还想隐藏对您可能正在使用的任何日志包的依赖(例如)?
如果您的实现中有依赖项,那么它们最好发布,因为它会使您的API用户更加悲痛,因为他们会在尝试使用您的代码之前知道可能存在哪些冲突。
不要忘记,您的用户实际上是开发人员,我相信他们宁愿预先了解任何地雷或要求。
编辑 - 关于OSGi:
OSGi肯定会处理您的冲突依赖项问题,但它也将依赖于在OSGi环境中部署,您未提及的是您的客户端。此外,仍然不建议在捆绑中“隐藏”这些依赖项。 OSGi的本质允许那些令人困惑的依赖关系在同一个应用程序中进行cooexist。