其他分享
首页 > 其他分享> > acvitivi7 整合springboot

acvitivi7 整合springboot

作者:互联网

目录

零、前提

基础操作可以看我另外两篇,这里只写整合

链接: 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");
		}
	}
}

标签:acvitivi7,task,springboot,map,流程,activiti,整合,mysql,Test
来源: https://blog.csdn.net/qq_48721706/article/details/122512500