扩展点的介绍和入门

背景

在实际的开发过程中,我们经常面临着不断变化的业务需求。为了应对这些变化,我们需要设计灵活、可扩展的系统架构。扩展点作为一种设计模式,在Cola框架中发挥着重要的作用。在这篇文章中,将介绍扩展点的基本概念、Cola框架中的具体应用以及其背后的原理机制。

扩展点的理解

扩展点是对系统能力的扩展,是对能力的增强,使其具备原有能力做不到的事情。系统中通过预留扩展的能力,业务方可以根据自己的需求,实现个性化的逻辑。在Cola框架中,扩展点即是系统预留的可以扩展的接口,使得系统可以灵活地适应业务规则的变化。

解决的问题

扩展点的引入解决了一个重要问题:允许开发者在不改变原有流程的情况下,对业务规则进行方便的修改。这意味着即使在已有的系统基础上,业务需求发生变化时,我们也可以通过扩展点来实现新的逻辑,而无需对原有代码进行大幅度修改。

具体应用场景

在Cola框架中,扩展点的应用场景非常丰富。例如,我们可以通过扩展点来实现自定义的校验逻辑、自定义的数据转换器、自定义的错误处理器等。这些扩展点可以根据业务需求,自由组合,实现个性化的业务处理流程。

扩展点的使用步骤

  1. 定义扩展点接口:首先,我们需要定义一个扩展点接口,规定了扩展点的方法签名。
  2. 实现扩展点:开发者可以根据业务需求,实现扩展点接口的具体逻辑。
  3. 注册扩展点:Cola框架提供了注册扩展点的机制,通常使用注解来声明扩展点的实现类。
  4. 调用扩展点:在系统运行时,Cola框架会动态加载并调用注册的扩展点,实现业务逻辑的灵活调用。

扩展点的原理机制

扩展点的原理基于SPI(Service Provider Interface)机制。SPI是Java提供的一种扩展机制,允许系统动态加载和注册服务实现。在Cola框架中,扩展点的实现类通常通过使用注解来注册,然后由框架在运行时动态加载。

具体应用示例

让我们通过一个简单的示例来演示扩展点的使用。

假设我们有一个需求,需要实现一个自定义的计算运费的功能。我们先定义一个扩展点接口:

java 复制代码
// 定义扩展点接口
public interface FreightExtPt extends ExtensionPointI {
    /**
     * 计算运费
     * @param freightCostDTO
     * @return
     */
    BigDecimal calFreightCost(CalFreightCostDTO freightCostDTO);
}

然后,我们实现这个接口的具体校验器:

kotlin 复制代码
// 实现扩展点
@Extension(bizId = 'pop')
public class FreightR5Handler implements FreightValidatorExtPt {
    @Override
    public BigDecimal calFreightCost(CalFreightCostDTO freightCostDTO) {
        return BigDecimal.ZERO;
    }
}

在这个示例中,我们使用了@Extension注解来标记这个类是一个扩展点的实现类, bizId代表业务类型

最后,我们可以在系统中调用这个扩展点:

kotlin 复制代码
// 调用扩展点
public class test {

  @Resource
  private ExtensionExecutor executor;
  
  public BigDecimal calFreightCost(AftersalesOrderCommonDTO aftersalesOrderCommonDTO, AuditParameter auditParameter) {
    return extensionExecutor.execute(FreightValidatorExtPt.class, aftersalesOrderCommonDTO.getBizScenario(), extension -> extension.calFreightCost(AfterSalesOrderFlowConvert.INSTANCE.convertCalFreightCostDTO(aftersalesOrderCommonDTO, auditParameter)));
  }
}

当pop业务请求时,会根据业务身份选择pop的扩展点进行执行,而当其他业务请求时,会使用默认的能力扩展,这样就可以实现业务的差异化处理,如果有其他业务有不同的业务逻辑,只需要对其进行扩展即可。

结论

通过本文的介绍,我们了解了扩展点的基本概念、在Cola框架中的具体应用以及其背后的原理机制。扩展点允许开发者在不改变原有流程的情况下,对业务规则进行方便的修改,从而使系统更加灵活、可扩展。在未来的开发中,我们可以充分利用扩展点机制,实现更加灵活、可定制的业务逻辑。

相关推荐
wuxinzhe76cmd4 分钟前
JVM 垃圾回收基础:从 STW 到分代收集(附 G1/ZGC 导读)
后端
MrSYJ9 分钟前
TCP协议理解
后端·tcp/ip
boolean的主人10 分钟前
超实用!5 个 MySQL 索引优化实战场景(附 10 万测试数据)
后端
BBmmo11 分钟前
JDBC基础篇
后端
用户642780069378813 分钟前
elpis-core 第一阶段学习心得与收获
后端
kfaino15 分钟前
码农的AI翻身·前传 一个大模型从出生到上岗的全过程
后端·aigc
IT_陈寒22 分钟前
Vue的这个响应式陷阱让我熬到凌晨三点
前端·人工智能·后端
葫芦和十三1 小时前
图解 MongoDB 17|大集合与工作集:数据超过内存怎么办
后端·mongodb·面试
kfaino9 小时前
码农的AI翻身(三)你好,我叫 Embedding
后端·ai编程
葫芦和十三9 小时前
图解 MongoDB 18|复制集拓扑:Primary、Secondary 和 Arbiter 的分工
后端·mongodb·面试