若依分离版后端集成 Camunda 7 工作流引擎

一、Camunda 简介

Camunda 是一款基于 Java 的开源流程自动化平台,主要聚焦以下三个核心领域:

  • 工作流与流程自动化(BPMN)

    使用 BPMN(业务流程模型与标注)完成流程建模、自动执行与监控。

  • 案例管理(CMMN)

    适用于各种非线性、不可预定义步骤的业务场景。

  • 决策管理(DMN)

    通过决策表管理业务规则,使流程逻辑更加清晰灵活。

Camunda 将 BPMN、CMMN、DMN 三种规范统一整合,提供了完整的流程建模、执行、监控能力,是后端流程引擎集成的理想选择。若依项目中接入 Camunda,可显著提升业务流程的自动化程度。

二、添加 Camunda 依赖

ruoyi-common 模块的 pom.xml 中引入 Camunda Spring Boot Starter 相关依赖:

XML 复制代码
<!-- Camunda 工作流依赖 -->
<dependency>
    <groupId>org.camunda.bpm.springboot</groupId>
    <artifactId>camunda-bpm-spring-boot-starter</artifactId>
<version>7.16.0</version>
</dependency>
<dependency>
    <groupId>org.camunda.bpm.springboot</groupId>
    <artifactId>camunda-bpm-spring-boot-starter-rest</artifactId>
    <version>7.16.0</version>
</dependency>
<dependency>
    <groupId>org.camunda.bpm.springboot</groupId>
    <artifactId>camunda-bpm-spring-boot-starter-webapp</artifactId>
    <version>7.16.0</version>
</dependency>

引入后,Camunda 的流程引擎、REST API 以及 Web 管理界面将自动启用。

三、在 application.yml 中添加基础配置

为了正常登录 Camunda 后台,需要在 application.yml 中配置管理员信息与过滤条件:

XML 复制代码
camunda:
  bpm:
    admin-user:
      id: admin
      password: 123456
      firstName: kfm
    filter:
      create: All tasks

配置完成后,Camunda 会在首次启动时自动创建此管理员账号。

四、修改数据库连接 URL

Camunda 使用自动建表机制,为确保扫描数据库 catalog 正常,需要在数据库链接末尾追加:

XML 复制代码
&nullCatalogMeansCurrent=true

若省略此参数,Camunda 可能无法定位库表,从而导致初始化失败。

五、配置匿名访问权限

Camunda Web 管理界面需要对静态资源、API 接口开放访问,因此需在 ruoyi-framework 模块中的 SecurityConfig.java 添加匿名放行策略:

java 复制代码
.antMatchers("/login","/register","/captchaImage").permitAll()
.antMatchers("/app/**").permitAll()
.antMatchers("/camunda/**").permitAll()

此操作确保 Camunda 的 Webapp 和 REST API 能正常访问。

六、注释原有 /index 路径映射

由于若依默认提供 /index 路由,而 Camunda Webapp 同样使用 /app 系列入口,为避免冲突,需要注释掉项目中与 Camunda 路径冲突的 /index 路径。

完成后,Camunda 的管理页面将保持正常访问。

七、启动项目并登录 Camunda

运行后端服务后,通过浏览器访问 Camunda Web 管理界面地址(服务器 IP + 项目端口),使用前面配置的管理员账号进行登录:

登录成功后即可看到 Camunda 的控制台,包括流程定义、任务管理、部署情况等模块。

八、检查 Camunda 自动生成的数据库表

首次启动时,Camunda 会在指定的 MySQL 数据库中自动创建 49 张系统表,涵盖流程实例、任务、授权、部署记录等多种数据结构。

当这些表成功生成且引擎启动无报错时,说明 Camunda 已成功集成到若依后端系统中。

通过上述步骤,若依分离版后端已顺利完成与 Camunda7 工作流引擎的集成工作。此后即可在项目中实现流程建模、流程驱动业务、任务管理等功能,为业务自动化提供强大支撑。

相关推荐
xieliyu.6 小时前
Java算法精讲:双指针(三)
java·开发语言·算法
明夜之约6 小时前
Spring Boot 自动装配源码
java·spring boot·后端
Leaton Lee6 小时前
Spring Boot分层架构详解:从Controller到Service再到Mapper的完整流程
java·spring boot·后端·架构
Jinkxs6 小时前
Resilience4j- 与 Spring Boot 快速集成:自动配置与基础注解使用
java·spring boot·后端
辣机小司6 小时前
【踩坑记录:Spring Boot 配置文件读取值不一致?警惕 YAML 的“八进制陷阱”与 SnakeYAML 版本之谜】
java·spring boot·后端·yaml·踩坑记录
fangdengfu1237 小时前
ES分析系统各个服务日志占用量
java·前端·elasticsearch
云烟成雨TD7 小时前
Spring AI 1.x 系列【51】可观测性技术选型
java·人工智能·spring
星越华夏7 小时前
ESP32-CAM图像传输项目说明文档
java·后端·struts·esp32
Jinkxs8 小时前
Java 跨域14-Java 与区块链(Hyperledger)集成
java·开发语言·区块链
晨曦中的暮雨9 小时前
Golang速通(Javaer版)
java·开发语言·后端·golang