目录
零、前提
基础操作可以看我另外两篇,这里只写整合
链接: https://blog.csdn.net/qq_48721706/article/details/122514133 基础篇
链接: https://blog.csdn.net/qq_48721706/article/details/122514174 进阶篇
一、配置
1、依赖
<dependency>
<groupId>org.activiti</groupId>
<artifactId>activiti-spring-boot-starter</artifactId>
<version>7.0.0.Beta1</version>
</dependency>
<dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
<version>${mysql-connector-java.version}</version>
<scope>runtime</scope>
</dependency>
<!-- 引入阿里数据库连接池 -->
<dependency>
<groupId>com.alibaba</groupId>
<artifactId>druid</artifactId>
<version>${druid.version}</version>
</dependency>
2、yml
spring:
datasource:
url: jdbc:mysql://localhost:3306/springboot-activiti?useUnicode=true&characterEncoding=UTF-8&useSSL=false&serverTimezone=UTC&nullCatalogMeansCurrent=true
username: root
password: root
driver-class-name: com.mysql.jdbc.Driver
type: com.alibaba.druid.pool.DruidDataSource
activiti:
#1.flase:默认值。activiti在启动时,对比数据库表中保存的版本,如果没有表或者版本不匹配,将抛出异常
#2.true: activiti会对数据库中所有表进行更新操作。如果表不存在,则自动创建
#3.create_drop: 在activiti启动时创建表,在关闭时删除表(必须手动关闭引擎,才能删除表)
#4.drop-create: 在activiti启动时删除原来的旧表,然后在创建新表(不需要手动关闭引擎)
database-schema-update: true
#检测历史表是否存在 activiti7默认没有开启数据库历史记录 启动数据库历史记录
db-history-used: true
#记录历史等级 可配置的历史级别有none, activity, audit, full
#none:不保存任何的历史数据,因此,在流程执行过程中,这是最高效的。
#activity:级别高于none,保存流程实例与流程行为,其他数据不保存。
#audit:除activity级别会保存的数据外,还会保存全部的流程任务及其属性。audit为history的默认值。
#full:保存历史数据的*别,除了会保存audit级别的数据外,还会保存其他全部流程相关的细节数据,包括一些 流程参数等。
history-level: full
#校验流程文件,默认校验resources下的processes文件夹里的流程文件
check-process-definitions: false
二、创建bpmn文件
Activiti7可以自动部署流程,前提是在resources目录下,创建一个新的目录processes,用来放置bpmn文件。
创建bpmn文件,画好图
三、生成25表
运行application,直接会生成25张表
四、操作
其他更多操作,可以看我另外两篇
@Slf4j
@SpringBootTest
class ActivitiSpringbootApplicationTests {
@Autowired
private RuntimeService runtimeService;
@Autowired
private TaskService taskService;
@Autowired
private RepositoryService repositoryService;
@Autowired
private HistoryService historyService;
@Test
void contextLoads() {
}
/**
* 部署流程
*/
@Test
public void deployment(){
Deployment deployment = repositoryService.createDeployment()
.name("测试流程")
.addClasspathResource("processes/test.bpmn")
.deploy();
System.out.println("流程部署id"+deployment.getId());
System.out.println("流程部署name"+deployment.getName());
System.out.println("流程部署key"+deployment.getKey());
}
/**
* 开启流程,设置受让人和候选人
*/
@Test
public void start(){
Map<String, Object> map = new HashMap<>();
map.put("assignee","hmb");
map.put("assignee1","hmb1");
map.put("assignee2","hmb2");
map.put("assignee3","hmb3");
map.put("assignee4","hmb4");
runtimeService.startProcessInstanceByKey("test",map);
}
/**
* 根据key和受让人完成任务
*/
@Test
public void complete(){
Task task = taskService.createTaskQuery()
.processDefinitionKey("test")
.taskAssignee("hmb")
.singleResult();
if (task!=null){
taskService.complete(task.getId());
}
}
/**
* 候选人拾取任务
*/
@Test
public void pickup(){
// 查询这个任务,有没有一个hmb1的候选人
List<Task> testList = taskService.createTaskQuery().processDefinitionKey("test")
.list();
for (Task task:testList) {
System.out.println("task.getId() = " + task.getId());
}
if (testList.get(0)!=null){ // 如果有,就拾取任务,把hmb1变成主负责人
// 拾取任务
taskService.claim(testList.get(0).getId(),"hmb1");
}
}
}