概述
Activiti是一个强大的BPM引擎,它能够帮助企业通过建模、部署和执行流程来优化业务流程。集成Activiti到Spring Boot可以使得流程的管理更加方便和高效,同时能够与现有的Spring应用程序集成得很好。
应用场景
集成Activiti到Spring Boot的典型应用场景包括但不限于:
- 业务流程自动化:通过定义和管理工作流程,自动化执行复杂的业务流程,提高工作效率和准确性。
- 审批流程管理:实现各种审批流程,如请假审批、报销审批等,通过流程图形化显示审批流程,方便管理和监控。
- 工作流系统集成:将工作流系统嵌入到现有的企业应用中,如ERP系统、CRM系统等,增强业务流程管理能力。
- 任务调度和执行:实现定时任务、异步任务的调度和执行,通过工作流引擎管理任务的执行顺序和状态。
示例代码
以下是一个简单的示例,演示如何在Spring Boot项目中集成Activiti并创建一个简单的工作流程。
1. 添加依赖
首先,在你的Spring Boot项目中,添加Activiti的依赖:
<dependency>
<groupId>org.activiti</groupId>
<artifactId>activiti-spring-boot-starter-basic</artifactId>
<version>7.1.100</version>
</dependency>
2. 创建工作流程定义
在resources目录下创建一个BPMN 2.0流程定义文件(例如:processes/simple-process.bpmn):
<?xml version="1.0" encoding="UTF-8"?>
<definitions xmlns="http://www.omg.org/spec/BPMN/20100524/MODEL"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xmlns:activiti="http://activiti.org/bpmn"
xmlns:bpmndi="http://www.omg.org/spec/BPMN/20100524/DI"
xmlns:omgdc="http://www.omg.org/spec/DD/20100524/DC"
xmlns:omgdi="http://www.omg.org/spec/DD/20100524/DI"
typeLanguage="http://www.w3.org/2001/XMLSchema"
expressionLanguage="http://www.w3.org/1999/XPath"
targetNamespace="http://www.activiti.org/test">
<process id="simple-process" name="Simple Process" isExecutable="true">
<startEvent id="start" />
<sequenceFlow id="flow1" sourceRef="start" targetRef="task1" />
<userTask id="task1" name="User Task" />
<sequenceFlow id="flow2" sourceRef="task1" targetRef="end" />
<endEvent id="end" />
</process>
</definitions>
这个流程定义包含了一个简单的开始事件、用户任务和结束事件。
3. 配置Activiti
在application.properties
中配置Activiti相关属性:
# 数据库配置
spring.datasource.url=jdbc:mysql://localhost:3306/activiti?characterEncoding=UTF-8
spring.datasource.username=root
spring.datasource.password=password
spring.datasource.driver-class-name=com.mysql.cj.jdbc.Driver
# Activiti配置
spring.activiti.database-schema-update=true
spring.activiti.database-schema=classpath:org/activiti/db/activiti.mysql.create.engine.sql
spring.activiti.check-process-definitions=true
spring.activiti.history-level=full
4. 编写服务类
创建一个服务类来管理工作流程的部署和执行:
import org.activiti.engine.RepositoryService;
import org.activiti.engine.RuntimeService;
import org.activiti.engine.TaskService;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;
import org.springframework.transaction.annotation.Transactional;
@Service
@Transactional
public class WorkflowService {
@Autowired
private RepositoryService repositoryService;
@Autowired
private RuntimeService runtimeService;
@Autowired
private TaskService taskService;
public void deployProcess() {
repositoryService.createDeployment()
.addClasspathResource("processes/simple-process.bpmn")
.deploy();
}
public void startProcessInstance() {
runtimeService.startProcessInstanceByKey("simple-process");
}
public void completeTask(String taskId) {
taskService.complete(taskId);
}
}
5. 控制器类
创建一个REST控制器来处理请求,并调用上述服务类来管理工作流程:
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.*;
@RestController
@RequestMapping("/workflow")
public class WorkflowController {
@Autowired
private WorkflowService workflowService;
@PostMapping("/deploy")
public String deployProcess() {
workflowService.deployProcess();
return "Process deployed successfully";
}
@PostMapping("/start")
public String startProcessInstance() {
workflowService.startProcessInstance();
return "Process instance started successfully";
}
@PostMapping("/complete")
public String completeTask(@RequestParam String taskId) {
workflowService.completeTask(taskId);
return "Task completed successfully";
}
}
运行和测试
- 启动你的Spring Boot应用程序。
- 使用POST请求访问
/workflow/deploy
来部署工作流程定义。 - 使用POST请求访问
/workflow/start
来启动工作流程实例。 - 使用POST请求访问
/workflow/complete?taskId=xxx
来完成用户任务,其中taskId
是任务的ID。
总结
通过以上步骤,你可以在Spring Boot应用程序中集成Activiti,并实现简单的工作流程定义、部署和执行。这样的集成可以帮助你实现业务流程的自动化管理,提高工作效率和流程透明度。根据具体需求,你可以进一步扩展和定制工作流程,以满足复杂的业务场景需求。