• Activiti6.0集成SpringBoot2.1.6+idea详细基础开发


    开发环境:JDK1.8+idea工具+maven

    首先idea下载插件File->settings->plugins->Marketplace  直接搜索actiBPM下载,之后重启idea。

    流程图中中文乱码问题:

    找到idea安装目录bin目录下如下图所示两个文件,用编辑器打开,在文件末尾添加 -Dfile.encoding=UTF-8 ,然后重启idea,再打开流程图就会发现中文已经可以正常显示了。

    创建springboot项目:

    引入pom文件包

    需要的mysql已经mybatis

    启动类是增加:

    1.  
      /**
    2.  
      * 去除springboot默认的basic验证,否则访问项目需要提供用户名和密码
    3.  
      */
    4.  
      @SpringBootApplication(exclude = {LiquibaseAutoConfiguration.class,
    5.  
      org.springframework.boot.autoconfigure.security.servlet.SecurityAutoConfiguration.class,
    6.  
      SecurityAutoConfiguration.class})
    7.  
      public class LambdaApplication {
    8.  
       
    9.  
      public static void main(String[] args) {
    10.  
      SpringApplication.run(LambdaApplication.class, args);
    11.  
      }
    12.  
       
    13.  
      }

    数据源直接使用yml或者properties配置,activiti会自动读取配置。但需要进行配置,加载数据源

    1.  
      /**
    2.  
      *这个yml配置绝对不能少,否则启动会失败
    3.  
      * 意思是每次启动对自动创建的表进行检验
    4.  
      */
    5.  
      spring:
    6.  
      activiti:
    7.  
      history-level: full
    8.  
      check-process-definitions: false

    然后直接appliction直接启动项目,会发现数据库中自动创建了28张表

     

    大致介绍一下这些表:

    • ACT_GE 通用类
    • ACT_HI 历史记录类
    • ACT_ID 用户信息类
    • ACT_RE 流程实例类
    • ACT_RU 运行时类

    详细的介绍

    表名说明
    ACT_EVT_LOG 事件日志表(实验性质)
    ACT_GE_BYTEARRAY 通用的流程定义和流程资源
    ACT_GE_PROPERTY 系统相关属性
    ACT_HI_ACTINST 历史的流程实例
    ACT_HI_ATTACHMENT 历史的流程附件
    ACT_HI_COMMENT 历史的批注信息
    ACT_HI_DETAIL 历史的流程运行中的细节信息
    ACT_HI_IDENTITYLINK 历史的流程运行过程中用户关系
    ACT_HI_PROCINST 历史的流程实例
    ACT_HI_TASKINST 历史的任务实例
    ACT_HI_VARINST 历史的流程运行中的变量信息
    ACT_ID_GROUP
    ACT_ID_INFO 用户详细信息
    ACT_ID_MEMBERSHIP 用户和组关系的中间表
    ACT_ID_USER 用户表
    ACT_RE_DEPLOYMENT 部署的流程信息
    ACT_RE_MODEL 流程模型信息
    ACT_RE_PROCDEF 流程定义信息
    ACT_RU_DEADLETTER_JOB 存储执行失败的任务表(异步)
    ACT_RU_EVENT_SUBSCR 运行时事件
    ACT_RU_EXECUTION 运行时流程执行实例
    ACT_RU_IDENTITYLINK 运行时用户关系信息
    ACT_RU_JOB 运行时作业(异步)
    ACT_RU_SUSPENDED_JOB 暂停运行的任务(异步)
    ACT_RU_TASK 运行时任务
    ACT_RU_TIMER_JOB 任务定时器表(异步)
    ACT_RU_VARIABLE 运行时变量表
    ACT_PROCDEF_INFO 流程定义信息表
    1.  
      @Autowired
    2.  
      private RuntimeService runtimeService;
    3.  
       
    4.  
      @Autowired
    5.  
      private TaskService taskService;
    6.  
       
    7.  
      @Autowired
    8.  
      private IdentityService identityService;
    9.  
       
    10.  
      @Autowired
    11.  
      private RepositoryService repositoryService;
    12.  
       
    13.  
      @Autowired
    14.  
      private ProcessEngine processEngine;
    15.  
       
    16.  
      @Autowired
    17.  
      private HistoryService historyService;

    springboot直接使用这些service管理操作这些表。就不再需要 processEngine.get***service();

    Service管理的表
    RepositoryService 通用类的表
    FormService 通过表单提交的任务的服务类
    HistoryService 历史记录表
    IdentityService 用户信息表
    ManagementService 自定义查询的服务类 managementService.executeCustomSql
    RuntimeService 运行时相关表
    TaskService 任务表, 可以查询 ACT_RU_ ACT_HI_

     在resources下创建一个:processes文件夹,放流程文件。之后右键点击文件夹:创建流程文件

    这是我创建的一个流程文件,直接保存即可。无需和eclipse一样需要去生成一个png文件。在使用repositoryService部署流程对象时他会在数据库的ACT_GE_BYTEARRAY 通用的流程定义和流程资源表中创建保存相应的png以及bpmn文件

    这我就不详细截图了:分别对应的是name名称,assignee以及委托人:组长是group,经理是manager,老板是boss 

    使用方法:

    发布流程:

    1.  
      /**
    2.  
      * 发布流程
    3.  
      *
    4.  
      * @throws IOException
    5.  
      */
    6.  
      @Test
    7.  
      public void deploymentProcesses_zip() throws IOException {
    8.  
       
    9.  
      Deployment deploy = repositoryService.createDeployment()//创建一个部署的对象
    10.  
      .name("请假流程定义")//创建流程名称
    11.  
      .addClasspathResource("processes/activiti_demo.bpmn")//指定zip完成部署
    12.  
      .deploy();
    13.  
      // long count = repositoryService.createProcessDefinitionQuery().count();
    14.  
      System.out.println("部署id" + deploy.getId());
    15.  
      System.out.println("部署名称" + deploy.getName());
    16.  
      // System.out.println("部署名称"+count);
    17.  
       
    18.  
      }

     启动流程:

    1.  
      /**
    2.  
      * 启动流程
    3.  
      * RuntimeService
    4.  
      */
    5.  
      @Test
    6.  
      public void startProcess() {
    7.  
      //可根据id、key、message启动流程
    8.  
      ProcessInstance processInstance = runtimeService.startProcessInstanceByKey("myProcess_1");
    9.  
      System.out.println(processInstance.getName());
    10.  
      System.out.println(processInstance.getProcessDefinitionId());
    11.  
      System.out.println(processInstance.getId());
    12.  
      }

    查看任务: 

    1.  
       
    2.  
      /**
    3.  
      * 查看任务
    4.  
      * TaskService
    5.  
      */
    6.  
      @Test
    7.  
      public void queryTask() {
    8.  
      //根据assignee(代理人)查询任务
    9.  
      String assignee = "manager";
    10.  
      List<Task> tasks = taskService.createTaskQuery().taskAssignee(assignee).list();
    11.  
       
    12.  
      int size = tasks.size();
    13.  
      for (int i = 0; i < size; i++) {
    14.  
      Task task = tasks.get(i);
    15.  
       
    16.  
      }
    17.  
      //获取最新一条
    18.  
      for (Task task : tasks) {
    19.  
      System.out.println("taskId:" + task.getId() +
    20.  
      ",taskName:" + task.getName() +
    21.  
      ",assignee:" + task.getAssignee() +
    22.  
      ",createTime:" + task.getCreateTime());
    23.  
      }
    24.  
      }

    办理任务:

    1.  
      /**
    2.  
      * 办理任务
    3.  
      */
    4.  
      @Test
    5.  
      public void handleTask() {
    6.  
      //根据上一步生成的taskId执行任务
    7.  
      String taskId = "12505";
    8.  
      taskService.complete(taskId);
    9.  
      }

    这就是一套简单的业务流程代码了。

    所有的数据可以根据相应的表进行查看,特别注意的是。这只是测试:在相应的项目中如果需要使用,需要根据具体的用户user以及功能权限进行逻辑处理

    • 源码地址:github源码 https://github.com/superqinchao/activiti-demo/tree/feature/activiti_demo 分支feature/activiti_demo

    参考:https://blog.csdn.net/qinchao_mei/article/details/100661212

  • 相关阅读:
    CSS初识
    HTML 初识
    索引
    表查询前之数据导入
    mysql练习2
    AMP+EPP3.0的开发环境配置
    C++异步编程资料汇集贴
    Windows8中如何打包和安装一个本地的Metro类型应用(转)
    std::string, std::wstring, wchar_t*, Platform::String^ 之间的相互转换
    windows RT开发笔记:WinRT DLL及其调用研究
  • 原文地址:https://www.cnblogs.com/sea520/p/13647238.html
Copyright © 2020-2023  润新知