扩展点的介绍和入门

背景

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

相关推荐
ღ᭄ꦿ࿐Never say never꧂19 分钟前
微服务架构中的负载均衡与服务注册中心(Nacos)
java·spring boot·后端·spring cloud·微服务·架构·负载均衡
.生产的驴28 分钟前
SpringBoot 消息队列RabbitMQ 消息确认机制确保消息发送成功和失败 生产者确认
java·javascript·spring boot·后端·rabbitmq·负载均衡·java-rabbitmq
海里真的有鱼36 分钟前
Spring Boot 中整合 Kafka
后端
CaritoB41 分钟前
中台架构下的数据仓库与非结构化数据整合
数据仓库·架构
布瑞泽的童话42 分钟前
无需切换平台?TuneFree如何搜罗所有你爱的音乐
前端·vue.js·后端·开源
写bug写bug1 小时前
6 种服务限流的实现方式
java·后端·微服务
离开地球表面_991 小时前
索引失效?查询结果不正确?原来都是隐式转换惹的祸
数据库·后端·mysql
Victor3561 小时前
Oracle(138)如何监控数据库性能?
后端
不修×蝙蝠2 小时前
eclipse使用 笔记02
前端·笔记·后端·eclipse
吃面不喝汤664 小时前
Flask + Swagger 完整指南:从安装到配置和注释
后端·python·flask