如何解决Java SPI 在非开源 [基于公司] 项目中的使用
最近了解了Java SPI,我认为只有第三方库实现接口才有用,比如slf4j
和jdbc
[即最有可能的是,开源库]。如果应用程序是允许最终用户创建某物的自定义实现的产品,它也可能很有用。
但是对于在公司开发软件,我们只向客户端公开API,而最终客户端永远没有定制任何实现的权利,是否有任何理由使用Java SPI来实现接口?
例如,假设我正在开发一个支付系统,它直接连接到不同的银行系统 [例如摩根士丹利、中国银行、德意志银行……],但是每个系统肯定会有不同的 API,也许我们的服务器需要以不同的方式处理请求和响应。因此我们必须创建一个API来包装这些信息,以便其他开发者调用这些服务,而不必担心不同银行系统之间的差异。
public interface PaymentInterface {
String bankName();
boolean pay(Customer customer,BigDecimal amount);
}
在这种情况下,我可以在同一个 Jar 中,创建一个直接实现接口的方法,然后创建一个静态工厂方法,用于动态选择不同的 PaymentInterface。然后就可以走了。
当然,我们可以创建一个SPI,并定义meta-inf/service xxx文件来指定我们在XXX和YYY中实现SPI。但是当我们无法预见 SPI 的未来实现将建立在外部 jar 上,但在同一个 jar 中。是否有使用 SPI 的任何理由?
让我重新表述我的问题,
程序员/公司很少使用Java SPI吗?除非你在做开源项目,比如 spring
、dubbo
、slf4j
?
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。