Activity代码实现

简介: 本文介绍如何使用Activiti工作流引擎完成流程的创建、部署、启动、查询与任务处理。通过创建bpmn文件定义流程,编写代码部署流程定义,启动流程实例并查询当前任务,最终完成任务实现流程流转。整个过程涵盖核心API使用与数据库表变化,帮助快速掌握Activiti基础应用。

1 创建bpmn流程

  1. resources下新建一个文件夹,名称随意,这里我们叫:bpmn
  2. 右键,新创建一个:bpmnFile,名称随意,这里我们叫:hello.bpmn

  1. 拖拽生成流程节点信息,这里我们简单操作,视频操作流程如下:

此处为语雀视频卡片,点击链接查看:bpmn操作視頻.mp4


好了,截止目前我们就生成了一个简单的,单节点审批的工作流。接下来我们就将以此流程作为Demo,开始我们的学习之路。

2 部署流程定义

此代码是模拟我们开发好一套审批流程,后续员工就可以发起这个流程

请确保你已正确配置数据库连接(端口、用户名、密码),数据库处于启动状态,并且在本地创建了对应的数据库:activiti(名称可以随意)。

代码编写

@Test
public void deploymentProcessDefinition(){
    //创建ProcessEngine对象
    ProcessEngine processEngine = ProcessEngines.getDefaultProcessEngine();
    //获取RepositoryService对象
    RepositoryService repositoryService = processEngine.getRepositoryService();
    //进行部署
    Deployment deployment = repositoryService
            .createDeployment()
            .name("测试入门案例")
            .addClasspathResource("bpmn/hello.bpmn")
            .deploy();
    //输出部署的一些信息
    System.out.println("流程部署ID:"+deployment.getId());
    System.out.println("流程部署名称:"+deployment.getName());
}

上述代码唯一需要注意的地方,就是:addClasspathResource 中的路径,如果读者们与我保持不一致,请记得及时修改。

代码测试

运行单测,会发现日志中打印了大量的DDL语句,这是因为Activiti作为一款成熟的工作流引擎框架,他已经有了完善的数据库:

执行完成我们在最后的日志中看到输出结果:

此时我们去刷新数据库,会发现多了25张表,如下(大概表分类我们放在:04-Activiti拓展篇讲解,这里只讲最简单的上手Demo):

此时,最关键的来了:我们去:act_re_procdef中会发现有我们刚才的流程定义:

这就验证了我们的流程定义代码测试成功。相当于我们公司现在有了一个单节点的审批流程,后面就等着用户发起,这个流程就可以使用起来。

3 启动流程实例

此代码模拟的就是某个用户开始提交流程,此时就会开启某个流程,如下

@Test
public void startProcessInstance(){
    //获取与正在执行的流程示例和执行对象相关的Service
    ProcessInstance processInstance = ProcessEngines.getDefaultProcessEngine().getRuntimeService()
            //使用流程定义的key启动实例,key对应bpmn文件中id的属性值,默认按照最新版本流程启动
            .startProcessInstanceByKey("myProcess_1");
    System.out.println("流程实例ID:"+processInstance.getId());
    System.out.println("流程实例定义ID:"+processInstance.getProcessDefinitionId());
}

这里面需要注意的是:流程实例的key,对应表:act_re_procdef.key字段,二者必须保持一致,也就是bpmn文件id属性值。

当我们执行完成,输出打印如下:

此时我们去:act_ru_task 表中可以看到生成一个新的task数据,即当前用户开启了一个新的流程

同时可以查看到流程的多个任务节点信息:act_ru_execution

4 查询当前任务

此代码模拟员工查询目前审批在哪个节点,好催促对应审批人员进行审批

@Test
public void findPersonalTask(){
    //与正在执行的任务相关的Service
    List<Task> list = ProcessEngines.getDefaultProcessEngine().getTaskService()
            .createTaskQuery()  //创建查询任务对象
//          .taskAssignee("UserTask")  //指定个人任务查询,指定办理人
            .list();
    if(list != null && list.size() > 0){
        for(Task task : list){
            System.out.println("任务ID" + task.getId());
            System.out.println("任务名称" + task.getName());
            System.out.println("任务创建时间" + task.getCreateTime());
            System.out.println("任务指定人" + task.getAssignee());
            System.out.println("任务流程实例ID" + task.getProcessInstanceId());
            System.out.println("任务执行ID" + task.getExecutionId());
            System.out.println("任务流程定义ID" + task.getProcessDefinitionId());
        }
    }
}

运行后代码输出如下:

5 完成指定任务

此代码模拟某个用户完成对应的节点,即:审批通过/拒绝,流程就会自动流转至下一个节点

@Test
public void completePersonalTask(){
    // 对应task表的id
    ProcessEngines.getDefaultProcessEngine()
            .getTaskService()
            .complete("2505");
}

需要注意的是,此id对应的是上述:4 查询当前任务 返回任务ID保持一致。

当运行完成后,表:act_ru_task、act_ru_execution这种进行中数据都会清空,进入到:act_hi_**表中。


以上我们就完成了一个简单的工作流引擎代码编写与测试。

6 完整代码汇总

package com.demo;
import org.activiti.engine.ProcessEngine;
import org.activiti.engine.ProcessEngines;
import org.activiti.engine.RepositoryService;
import org.activiti.engine.repository.Deployment;
import org.activiti.engine.runtime.ProcessInstance;
import org.activiti.engine.task.Task;
import org.junit.Test;
import java.util.List;
public class ActivitiTest {
    @Test
    public void deploymentProcessDefinition(){
        //创建ProcessEngine对象
        ProcessEngine processEngine = ProcessEngines.getDefaultProcessEngine();
        //获取RepositoryService对象
        RepositoryService repositoryService = processEngine.getRepositoryService();
        //进行部署
        Deployment deployment = repositoryService
                .createDeployment()
                .name("测试入门案例")
                .addClasspathResource("bpmn/hello.bpmn")
                .deploy();
        //输出部署的一些信息
        System.out.println("流程部署ID:"+deployment.getId());
        System.out.println("流程部署名称:"+deployment.getName());
    }
    @Test
    public void startProcessInstance(){
        //获取与正在执行的流程示例和执行对象相关的Service
        ProcessInstance processInstance = ProcessEngines.getDefaultProcessEngine().getRuntimeService()
                //使用流程定义的key启动实例,key对应bpmn文件中id的属性值,默认按照最新版本流程启动
                .startProcessInstanceByKey("myProcess_1");
        System.out.println("流程实例ID:"+processInstance.getId());
        System.out.println("流程实例定义ID:"+processInstance.getProcessDefinitionId());
    }
    @Test
    public void findPersonalTask(){
        //与正在执行的任务相关的Service
        List<Task> list = ProcessEngines.getDefaultProcessEngine().getTaskService()
                .createTaskQuery()  //创建查询任务对象
//          .taskAssignee("UserTask")  //指定个人任务查询,指定办理人
                .list();
        if(list != null && list.size() > 0){
            for(Task task : list){
                System.out.println("任务ID" + task.getId());
                System.out.println("任务名称" + task.getName());
                System.out.println("任务创建时间" + task.getCreateTime());
                System.out.println("任务指定人" + task.getAssignee());
                System.out.println("任务流程实例ID" + task.getProcessInstanceId());
                System.out.println("任务执行ID" + task.getExecutionId());
                System.out.println("任务流程定义ID" + task.getProcessDefinitionId());
            }
        }
    }
    @Test
    public void completePersonalTask(){
        // 对应task表的id
        ProcessEngines.getDefaultProcessEngine()
                .getTaskService()
                .complete("2505");
    }
    /**
     * 1-2-3-4
     *
     * 2-1-3-4
     * 3-1-2-4
     * 流程编排、流程可视化
     */
}
目录
相关文章
|
IDE 安全 API
copilot在pycharm的应用
copilot在pycharm的应用
1523 4
copilot在pycharm的应用
|
3月前
|
数据采集 人工智能 自然语言处理
2026春招:我是如何靠一个OpenClaw项目拿下大厂产品岗Offer的?
文科零基础女生,靠OpenClaw打造“AI晨报助手”,0代码实现信息自动采集、摘要与推送,真实解决春招信息过载痛点。项目展现产品思维、AI应用深度与落地能力,助力斩获二线大厂产品岗Offer,薪资超预期。
|
11月前
|
定位技术 Android开发 数据安全/隐私保护
抖音虚拟位置软件, 修改定位位置app,抖音虚拟位置修改
这些代码展示了如何模拟GPS位置变化和Android设备上的虚拟定位功能。第一个模块模拟了城市间的移动轨迹
|
11月前
|
人工智能 搜索推荐 小程序
AI题库考试系统
本平台融合AI智能技术,打造高效课程试题库,支持PC、手机在线刷题,提供智能出题、自动解析、错题回顾、背题模式等功能,覆盖章节练习、笔记收藏、多端同步,助力学员精准提分,全面提升学习效率。
|
存储 负载均衡 监控
自适应负载均衡算法原理和实现
自适应负载均衡算法原理和实现
|
供应链 数据挖掘 API
1688app 商品详情接口系列(1688API)
1688作为国内知名批发采购平台,提供了一系列商品详情接口(API),助力企业和开发者获取商品基础、价格、库存及供应商信息。通过Python示例代码展示如何调用这些接口,应用场景涵盖采购决策辅助、数据分析与市场调研、电商平台整合及供应链管理系统的优化,为企业和采购商提供有力的数据支持,提升业务效率和竞争力。
611 15
|
XML 编解码 数据格式
Python 字符串str详解(超详细)(二)
Python 字符串str详解(超详细)(二)
564 0
|
机器学习/深度学习 人工智能 自然语言处理
【大模型】什么是大型语言模型(LLM)?
【5月更文挑战第4天】【大模型】什么是大型语言模型(LLM)?
|
机器学习/深度学习 存储 算法
一文让你掌握22个神经网络训练技巧
一文让你掌握22个神经网络训练技巧
一文让你掌握22个神经网络训练技巧
|
机器学习/深度学习 存储 前端开发
大模型应用框架-LangChain(二)
LangChain由 Harrison Chase 创建于2022年10月,它是围绕LLMs(大语言模型)建立的一个框架,LLMs使用机器学习算法和海量数据来分析和理解自然语言,GPT3.5、GPT4是LLMs最先进的代表,国内百度的文心一言、阿里的通义千问也属于LLMs。LangChain自身并不开发LLMs,它的核心理念是为各种LLMs实现通用的接口,把LLMs相关的组件“链接”在一起,简化LLMs应用的开发难度,方便开发者快速地开发复杂的LLMs应用。 LangChain目前有两个语言的实现:python、nodejs。