扩展点的介绍和入门

背景

在实际的开发过程中,我们经常面临着不断变化的业务需求。为了应对这些变化,我们需要设计灵活、可扩展的系统架构。扩展点作为一种设计模式,在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框架中的具体应用以及其背后的原理机制。扩展点允许开发者在不改变原有流程的情况下,对业务规则进行方便的修改,从而使系统更加灵活、可扩展。在未来的开发中,我们可以充分利用扩展点机制,实现更加灵活、可定制的业务逻辑。

相关推荐
yours_Gabriel11 分钟前
【微服务】认识微服务
java·微服务·架构
Adolf_199323 分钟前
Django 自定义路由转换器
后端·python·django
ᝰꫝꪉꪯꫀ3611 小时前
JavaWeb——Mybatis
java·开发语言·后端·mybatis
机器之心1 小时前
跨模态大升级!少量数据高效微调,LLM教会CLIP玩转复杂文本
人工智能·后端
爱上语文2 小时前
Http 响应协议
网络·后端·网络协议·http
Smilejudy3 小时前
三行五行的 SQL 只存在于教科书和培训班
后端·github
斯普信专业组3 小时前
RabbitMQ原理架构解析:消息传递的核心机制
架构·rabbitmq·ruby
爱上语文3 小时前
Http 请求协议
网络·后端·网络协议·http
贝克街的天才3 小时前
据说在代码里拼接查询条件不够优雅?Magic-1.0.2 发布
java·后端·开源
monkey_meng3 小时前
【Rust Iterator 之 fold,map,filter,for_each】
开发语言·后端·rust