开发环境: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