一:WorkFlow简介

1:什么是工作流工作流(Workflow),指“业务过程的部分或整体在计算机应用环境下的自动化”。是对工作流程及其各操作步骤之间业务规则的抽象、概括描述。在计算机中,工作流属于计算机支持的协同工作(CSCW)的一部分。后者是普遍地研究一个群体如何在计算机的帮助下实现协同工作的。

2:工作流主要解决的主要问题是:为了实现某个业务目标,利用计算机在多个参与者之间按某种预定规则自动传递文档、信息或者任务。
3:工作流概念起源于生产组织和办公自动化领域,Activiti 是一个针对商务人士、 开发人员和系统管理员的轻量级的工作流和业务流程管理平台
4:例如:比如请假可以看做一个流程,首先需要提交审批给项目,项目经历审批完了就部门经理审批,部门经理审批完给总经理,一层一层的审批就可以使用activiti框架来完成

二:ssm整合activiti框架

1:需要用到的maven依赖
  1. <!-- https://mvnrepository.com/artifact/org.activiti/activiti-engine -->
  2. <dependency>
  3. <groupId>org.activiti</groupId>
  4. <artifactId>activiti-engine</artifactId>
  5. <version>5.22.0</version>
  6. </dependency>
  7.  
  8. <!--activiti整合ssm需要用到的jar-->
  9. <dependency>
  10. <groupId>org.activiti</groupId>
  11. <artifactId>activiti-spring</artifactId>
  12. <version>5.22.0</version>
  13. </dependency>

2:spring_activiti.xml文件

  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <beans xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
  3. xmlns="http://www.springframework.org/schema/beans"
  4. xsi:schemaLocation="http://www.springframework.org/schema/beans
  5. http://www.springframework.org/schema/beans/spring-beans.xsd">
  6.  
  7. <!-- 配置数据源连接池 -->
  8. <bean id="dataSource" class="com.alibaba.druid.pool.DruidDataSource" init-method="init" destroy-method="close">
  9. <!-- 数据库连接属性 -->-->
  10. <property name="url"
  11. value="jdbc:mysql://localhost:3306/pmsdb?useUnicode=true&amp;characterEncoding=utf-8&amp;allowMultiQueries=true&amp;useSSL=false"/>
  12. <property name="driverClassName" value="com.mysql.jdbc.Driver"/>
  13. <property name="username" value="root"/>
  14. <property name="password" value="root"/>
  15. <!-- 启用系统监控过滤器 -->
  16. <property name="filters" value="stat"/>
  17. <!-- 最大连接池数量 -->
  18. <property name="maxActive" value="200"/>
  19. <!-- 初始化时建立物理连接的个数-->
  20. <property name="initialSize" value="5"/>
  21. <!-- 最小连接池数量-->
  22. <property name="minIdle" value="5"/>
  23. <!-- 获取连接时最大等待时间,单位毫秒-->
  24. <property name="maxWait" value="60000"/>
  25. <!-- 销毁线程会检测连接的间隔时间,(单位毫秒)
  26. 如果连接空闲时间大于等于minEvictableIdleTimeMillis则关闭物理连接-->
  27. <property name="timeBetweenEvictionRunsMillis" value="60000"/>
  28. <!-- 连接保持空闲而不被驱逐的最小时间 -->
  29. <property name="minEvictableIdleTimeMillis" value="300000"/>
  30. <!--申请连接的时候检测,如果空闲时间大于timeBetweenEvictionRunsMillis,
  31. 执行validationQuery检测连接是否有效-->
  32. <property name="testWhileIdle" value="true"/>
  33. <!-- 申请连接时执行validationQuery检测连接是否有效 -->
  34. <property name="testOnBorrow" value="false"/>
  35. <!-- 归还连接时执行validationQuery检测连接是否有效-->
  36. <property name="testOnReturn" value="false"/>
  37. <!-- 是否缓存preparedStatement, mysql建议关闭-->
  38. <property name="poolPreparedStatements" value="false"/>
  39. <!-- 伪SQL,用于检查连接是否可用 -->
  40. <property name="validationQuery" value="select 1"/>
  41. </bean>
  42. <!-- 装配DataSource的事务管理器-->
  43. <bean id="txManager" class="org.springframework.jdbc.datasource.DataSourceTransactionManager">
  44. <!-- 需要注入一个DataSource -->
  45. <property name="dataSource" ref="dataSource"/>
  46. </bean>
  47.  
  48. <!--创建一个流程引擎的配置对象 这里我们使用的是Spring提供的流程引擎对象-->
  49. <bean id="processEngineConfiguration" class="org.activiti.spring.SpringProcessEngineConfiguration">
  50. <property name="dataSource" ref="dataSource"/>
  51. <property name="transactionManager" ref="txManager"/>
  52. <!-- 是否自动创建25张表 -->
  53. <property name="databaseSchemaUpdate" value="true"/>
  54.  
  55. <!--是否启动jobExecutor-->
  56. <property name="jobExecutorActivate" value="false"/>
  57. <property name="databaseType" value="mysql"/>
  58. <property name="activityFontName" value="宋体"/>
  59. <property name="labelFontName" value="黑体"/>
  60. </bean>
  61.  
  62. <!--<property name="xmlEncoding" value="utf-8"/>-->
  63. <!-- 创建一个流程引擎bean -->
  64. <bean id="processEngine" class="org.activiti.spring.ProcessEngineFactoryBean">
  65. <property name="processEngineConfiguration" ref="processEngineConfiguration"/>
  66. </bean>
  67.  
  68. <!--配置服务Bean,定义Service服务-->
  69. <!--工作流仓储服务,对所有atc_re开头的表进行操作-->
  70. <bean id="repositoryService" factory-bean="processEngine" factory-method="getRepositoryService"/>
  71. <!--工作流运行服务 对所有act_ru开头的表进行操作 -->
  72. <bean id="runtimeService" factory-bean="processEngine" factory-method="getRuntimeService"/>
  73. <!--工作流任务服务-->
  74. <bean id="taskService" factory-bean="processEngine" factory-method="getTaskService"/>
  75. <!--工作流历史数据服务 对所有的act_hi开头的表进行操作-->
  76. <bean id="historyService" factory-bean="processEngine" factory-method="getHistoryService"/>
  77. <!--工作流管理服务-->
  78. <bean id="managementService" factory-bean="processEngine" factory-method="getManagementService"/>
  79. <!--工作流唯一服务, 对所有以act_id开头的表进行增删改查-->
  80. <bean id="identityService" factory-bean="processEngine" factory-method="getIdentityService"/>
  81. <!--工作流管理服务-->
  82. <bean id="formService" factory-bean="processEngine" factory-method="getFormService"/>
  83.  
  84. </beans>

3:别忘了将spring.activiti.xml注入到spring容器中,交给spring容器管理

  1. <!--引入工作流配置文件-->
  2. <import resource="classpath*:spring-activiti.xml"/>

4.启动项目时,将生成25张框架自带的表

4.1:部分表的含义

序号

表名

说明

1

act_ge_bytearray

二进制数据表

2

act_ge_property

属性数据表存储整个流程引擎级别的数据,初始化表结构时,会默认插入三条记录,

3

act_hi_actinst

历史节点表

4

act_hi_attachment

历史附件表

5

act_hi_comment

历史意见表

6

act_hi_identitylink

历史流程人员表

7

act_hi_detail

历史详情表,提供历史变量的查询

8

act_hi_procinst

历史流程实例表

9

act_hi_taskinst

历史任务实例表

10

act_hi_varinst

历史变量表

11

act_id_group

用户组信息表

12

act_id_info

用户扩展信息表

13

act_id_membership

用户与用户组对应信息表

14

act_id_user

用户信息表

15.

act_re_deployment

部署信息表

16.

act_re_model

流程设计模型部署表

17

act_re_procdef

流程定义数据表

18

act_ru_event_subscr

throwEvent、catchEvent时间监听信息表

19

act_ru_execution

运行时流程执行实例表

20

act_ru_identitylink

运行时流程人员表,主要存储任务节点与参与者的相关信息

21

act_ru_job

运行时定时任务数据表

22

act_ru_task

运行时任务节点表

23

act_ru_variable

运行时流程变量数据表

5:测试流程,首先使用idea下载activiti插件actiBPM,下载后重启idea,画出流程图,并生成png图片

apply.bpmn

apply.png图片

  1. 5WorkFlowTest
  1. package com.htzs.pms.service.address.impl;
  2.  
  3. import org.activiti.engine.*;
  4. import org.activiti.engine.repository.Deployment;
  5. import org.activiti.engine.task.Task;
  6. import org.junit.Test;
  7. import org.junit.runner.RunWith;
  8. import org.springframework.beans.factory.annotation.Autowired;
  9. import org.springframework.test.context.ContextConfiguration;
  10. import org.springframework.test.context.junit4.SpringRunner;
  11. import org.springframework.test.context.web.WebAppConfiguration;
  12.  
  13. import java.util.List;
  14.  
  15. /**
  16. * @author : ywb
  17. * @createdDate : 2019/9/18
  18. * @updatedDate
  19. */
  20. @RunWith(SpringRunner.class)
  21. @ContextConfiguration(locations = {"classpath:dispatcher-dao.xml", "classpath:dispatcher-service.xml"})
  22. @WebAppConfiguration
  23. public class WorkFlowTest {
  24. /**
  25. * 测试activiti是否与spring整合成功,成功标志如下
  26. * 控制台输出org.activiti.engine.impl.ProcessEngineImpl@4721ee77说明已经整合成功
  27. */
  28. @Test
  29. public void test() {
  30. // 1.创建Activiti配置对象的实例
  31. ProcessEngineConfiguration configuration = ProcessEngineConfiguration
  32. .createStandaloneProcessEngineConfiguration();
  33. // 2.设置数据库连接信息
  34. // 设置数据库的类型
  35. configuration.setDatabaseType("mysql");
  36. // 设置数据库驱动
  37. configuration.setJdbcDriver("com.mysql.jdbc.Driver");
  38. // 设置jdbcURL
  39. configuration.setJdbcUrl("jdbc:mysql://localhost:3306/activiti?useUnicode=true&amp;characterEncoding=utf-8&amp;allowMultiQueries=true&amp;useSSL=false");
  40. // 设置用户名
  41. configuration.setJdbcUsername("root");
  42. // 设置密码
  43. configuration.setJdbcPassword("root");
  44. // 设置数据库建表策略
  45. /**
  46. * DB_SCHEMA_UPDATE_TRUE:如果不存在表就创建表,存在就直接使用
  47. * DB_SCHEMA_UPDATE_FALSE:如果不存在表就抛出异常
  48. * DB_SCHEMA_UPDATE_CREATE_DROP:每次都先删除表,再创建新的表
  49. */
  50. configuration.setDatabaseSchemaUpdate(ProcessEngineConfiguration.DB_SCHEMA_UPDATE_CREATE_DROP);
  51.  
  52. // 3.使用配置对象创建流程引擎实例(检查数据库连接等环境信息是否正确)
  53. ProcessEngine processEngine = configuration.buildProcessEngine();
  54. System.out.println(processEngine);
  55. }
  56.  
  57. /**
  58. * 第二种创建方式 一般使用最多的就是这种创建方式
  59. */
  60. @Test
  61. public void initActiviti() {
  62. ProcessEngine processEngine = ProcessEngines.getDefaultProcessEngine();
  63. System.out.println(processEngine);
  64. }
  65.  
  66. @Autowired
  67. private RepositoryService repositoryService;
  68.  
  69. @Autowired
  70. private RuntimeService runtimeService;
  71.  
  72. @Autowired
  73. private TaskService taskService;
  74.  
  75. /**
  76. * 部署流程定义
  77. */
  78. @Test
  79. public void deployProcess(){
  80. //得到流程部署的service
  81. Deployment deploy = repositoryService.createDeployment().name("请假流程001")
  82. .addClasspathResource("apply.bpmn")
  83. .addClasspathResource("apply.png").deploy();
  84. System.out.println("部署成功,流程id:"+deploy.getId());
  85. }
  86. /**
  87. * 启动流程
  88. */
  89. @Test
  90. public void startProcess(){
  91. //使用key启动流程
  92. runtimeService.startProcessInstanceByKey("myProcess_1");
  93. //使用id启动流程
  94. // runtimeService.startProcessInstanceById("myProcess_1:1:4");
  95. System.out.println("流程启动成功");
  96. }
  97. /**
  98. * 查询流程
  99. */
  100. @Test
  101. public void findProcess(){
  102. List<Task> tasks = taskService.createTaskQuery().taskAssignee("王五").list();
  103. for (Task task : tasks) {
  104. System.out.println("任务id"+task.getId());
  105. System.out.println("流程实例id"+task.getProcessInstanceId());
  106. System.out.println("执行实例id"+task.getExecutionId());
  107. System.out.println("流程定义id"+task.getProcessDefinitionId());
  108. System.out.println("任务名称"+task.getName());
  109. System.out.println("任务办理人"+task.getAssignee());
  110. }
  111. }
  112.  
  113. @Test
  114. public void completeProcess(){
  115. taskService.complete("10002");
  116. System.out.println("任务完成");
  117. }
  118.  
  119. }

三:使用SpringBoot 整合activiti框架并整合activiti流程设计器
1:需要使用的maven

  1. <dependencies>
  2. <dependency>
  3. <groupId>org.springframework.boot</groupId>
  4. <artifactId>spring-boot-starter-web</artifactId>
  5. </dependency>
  6. <dependency>
  7. <groupId>org.springframework.boot</groupId>
  8. <artifactId>spring-boot-starter-thymeleaf</artifactId>
  9. </dependency>
  10. <dependency>
  11. <groupId>net.sourceforge.nekohtml</groupId>
  12. <artifactId>nekohtml</artifactId>
  13. <version>1.9.22</version>
  14. </dependency>
  15. <dependency>
  16. <groupId>mysql</groupId>
  17. <artifactId>mysql-connector-java</artifactId>
  18. <scope>runtime</scope>
  19. </dependency>
  20. <dependency>
  21. <groupId>org.springframework.boot</groupId>
  22. <artifactId>spring-boot-starter-test</artifactId>
  23. <scope>test</scope>
  24. </dependency>
  25.  
  26. <!--activiti begin-->
  27. <dependency>
  28. <groupId>org.activiti</groupId>
  29. <artifactId>activiti-engine</artifactId>
  30. <version>${activiti.version}</version>
  31. </dependency>
  32.  
  33. <dependency>
  34. <groupId>org.activiti</groupId>
  35. <artifactId>activiti-spring</artifactId>
  36. <version>${activiti.version}</version>
  37. </dependency>
  38.  
  39. <dependency>
  40. <groupId>org.activiti</groupId>
  41. <artifactId>activiti-modeler</artifactId>
  42. <version>${activiti.version}</version>
  43. </dependency>
  44.  
  45. <dependency>
  46. <groupId>org.activiti</groupId>
  47. <artifactId>activiti-diagram-rest</artifactId>
  48. <version>${activiti.version}</version>
  49. </dependency>
  50. <!--activiti end-->
  51.  
  52. </dependencies>

2.application.yml文件

  1. server:
  2. port: 8085
  3. security:
  4. basic:
  5. enabled: false
  6.  
  7. spring:
  8. datasource:
  9. url: jdbc:mysql://localhost:3306/activiti??useUnicode=true&characterEncoding=utf8&autoReconnect=true
  10. username: root
  11. password: root
  12. thymeleaf:
  13. mode: LEGACYHTML5
  14. cache: false

3:java注解配置类

  1. package edu.nf.project.config;
  2.  
  3. import org.activiti.engine.*;
  4. import org.activiti.spring.ProcessEngineFactoryBean;
  5. import org.activiti.spring.SpringProcessEngineConfiguration;
  6. import org.springframework.beans.factory.annotation.Autowired;
  7. import org.springframework.context.annotation.Bean;
  8. import org.springframework.context.annotation.Configuration;
  9. import org.springframework.core.io.Resource;
  10. import org.springframework.core.io.support.PathMatchingResourcePatternResolver;
  11. import org.springframework.transaction.PlatformTransactionManager;
  12.  
  13. import javax.sql.DataSource;
  14. import java.io.IOException;
  15.  
  16. /**
  17. * @author : ywb
  18. * @createdDate : 2019/9/20
  19. * @updatedDate
  20. */
  21. @Configuration
  22. public class ActivitiConfiguration {
  23. @Autowired
  24. private DataSource dataSource;
  25. @Autowired
  26. private PlatformTransactionManager platformTransactionManager;
  27.  
  28. /**
  29. * 创建一个流程引擎的配置对象 这里我们使用的是Spring提供的流程引擎对象
  30. * 创建一个流程引擎的配置对象 这里我摸嗯使用的事Spring提供的流程引擎对象
  31. * @return
  32. */
  33. @Bean
  34. public SpringProcessEngineConfiguration springProcessEngineConfiguration(){
  35. SpringProcessEngineConfiguration spec = new SpringProcessEngineConfiguration();
  36. spec.setDataSource(dataSource);
  37. spec.setTransactionManager(platformTransactionManager);
  38. spec.setDatabaseSchemaUpdate("true");
  39. Resource[] resources = null;
  40. // 启动自动部署流程
  41. try {
  42. resources = new PathMatchingResourcePatternResolver().getResources("classpath*:bpmn/*.bpmn");
  43. } catch (IOException e) {
  44. e.printStackTrace();
  45. }
  46. spec.setDeploymentResources(resources);
  47. return spec;
  48. }
  49.  
  50. /**
  51. * 创建一个流程引擎bean
  52. * @return
  53. */
  54. @Bean
  55. public ProcessEngineFactoryBean processEngine(){
  56. ProcessEngineFactoryBean processEngineFactoryBean = new ProcessEngineFactoryBean();
  57. processEngineFactoryBean.setProcessEngineConfiguration(springProcessEngineConfiguration());
  58. return processEngineFactoryBean;
  59. }
  60.  
  61. /**
  62. * 工作流仓储服务,对所有atc_re开头的表进行操作-
  63. * @return
  64. * @throws Exception
  65. */
  66. @Bean
  67. public RepositoryService repositoryService() throws Exception{
  68. return processEngine().getObject().getRepositoryService();
  69. }
  70.  
  71. /**
  72. * 工作流运行服务 对所有act_ru开头的表进行操作
  73. * @return
  74. * @throws Exception
  75. */
  76. @Bean
  77. public RuntimeService runtimeService() throws Exception{
  78. return processEngine().getObject().getRuntimeService();
  79. }
  80.  
  81. /**
  82. * 工作流任务服务
  83. * @return
  84. * @throws Exception
  85. */
  86. @Bean
  87. public TaskService taskService() throws Exception{
  88. return processEngine().getObject().getTaskService();
  89. }
  90.  
  91. /**
  92. * 工作流历史数据服务 对所有的act_hi开头的表进行操作
  93. * @return
  94. * @throws Exception
  95. */
  96. @Bean
  97. public HistoryService historyService() throws Exception{
  98. return processEngine().getObject().getHistoryService();
  99. }
  100.  
  101. /**
  102. * 工作流唯一服务,对所有以act_id开头的表进行增删改查
  103. * @return
  104. * @throws Exception
  105. */
  106. public IdentityService identityService() throws Exception{
  107. return processEngine().getObject().getIdentityService();
  108. }
  109.  
  110. /**
  111. * 工作流管理服务
  112. * @return
  113. * @throws Exception
  114. */
  115. public FormService formService() throws Exception{
  116. return processEngine().getObject().getFormService();
  117. }
  118.  
  119. /**
  120. * 工作流管理服务
  121. * @return
  122. * @throws Exception
  123. */
  124. public ManagementService managementService() throws Exception{
  125. return processEngine().getObject().getManagementService();
  126. }
  127.  
  128. }

SSM整合activiti框架的更多相关文章

  1. SSM整合Activiti

    1.pom.xml <?xml version="1.0" encoding="UTF-8"?> <project xmlns="h ...

  2. SSM整合文件框架

    1.项目架构如图 web3.0项目,tomcat9.0,自动生成web.xml文件 按照mybatis配置,先自动生成dao层,更改相应信息 我mybatis如何配置:   https://www.c ...

  3. spring MVC框架入门(外加SSM整合)

    spring MVC框架 一.什么是sping MVC Spring MVC属于SpringFrameWork的后续产品,已经融合在Spring Web Flow里面.Spring 框架提供了构建 W ...

  4. SSM整合框架实现ajax校验

    SSM整合框架实现ajax校验   刚学习了ssm框架,ajax校验成功,分享下 1.导入jar包

  5. Spring框架学习笔记(4)——SSM整合以及创建Maven自定义模版

    Spring+Spring MVC+MyBatis+Maven SSM整合的核心还是Spring+MyBatis的整合,回顾一下MyBatis操作数据库流程,我们是使用一个SQLSessionFact ...

  6. springMVC:校验框架:多规则校验,嵌套校验,分组校验;ssm整合技术

    知识点梳理 课堂讲义 学习目标 能够阐述表单验证的分类和区别 能够运用表单验证的常用注解 能够编写表单验证的示例 能够编写SSM整合的应用案例 能够总结SSM整合的步骤 1 校验框架 1.1 入门-视 ...

  7. 阶段3 3.SpringMVC·_07.SSM整合案例_03ssm整合之编写Spring框架

    做整合要保证每个框架单独使用 先搭建Spring的框架,然后再整合别的框架.Spring是业务层的框架 spring的配置文件 这就表示是spring的配置文件 默认的约束不够,需要修改. <b ...

  8. SSM框架整合的最新打开方式(打造最详细的SSM整合教程)

    SSM整合 文章已托管到GitHub,大家可以去GitHub查看阅读,欢迎老板们前来Star!搜索关注微信公众号 [码出Offer] 领取各种学习资料! SSM 一.创建一个Maven项目 File ...

  9. Maven + 最新SSM整合

    . 1. 开发环境搭建 参考博文:Eclipse4.6(Neon) + Tomcat8 + MAVEN3.3.9 + SVN项目完整环境搭建 2. Maven Web项目创建 2.1. 2.2. 2. ...

随机推荐

  1. [Spring cloud 一步步实现广告系统] 2. 配置&Eureka服务

    父项目管理 首先,我们在创建投放系统之前,先看一下我们的工程结构: mscx-ad-sponsor就是我们的广告投放系统.如上结构,我们需要首先创建一个Parent Project mscx-ad 来 ...

  2. Unity进阶之ET网络游戏开发框架 04-资源打包

    版权申明: 本文原创首发于以下网站: 博客园『优梦创客』的空间:https://www.cnblogs.com/raymondking123 优梦创客的官方博客:https://91make.top ...

  3. Appium+python自动化(三十四)- 有图有真相,很美很精彩 - 屏幕截图和Android APP类型简介(超详解)

    简介 在实际自动化项目运行过程中,很多时候App可以会出现各种异常,为了更好的定位问题,除了捕捉日志我们还需要对运行时的设备状态来进行截屏.从而达到一种“有图有真相”的效果. 截图方法 方法1 sav ...

  4. 剑指offer总结一:字符、数字重复问题

    问题1:字符串中第一个不重复的字符 题目描述 请实现一个函数用来找出字符流中第一个只出现一次的字符.例如,当从字符流中只读出前两个字符"go"时,第一个只出现一次的字符是" ...

  5. java 局部变量成员变量区别

    首先,成员变量可直接初始化(即赋值),也可不赋值,不赋值java按照以下类型自动赋值 局部变量调用前必须初始化(赋值),java不会自动处理 局部变量可以和成员变量重名(但不建议),如果在当前对象的方 ...

  6. SpringBoot:Java High Level REST Client 搜索 API

    Springboot整合最新版elasticSearch参考之前的文章:SpingBoot:整合ElasticSearch 7.2.0 Search API SearchRequest用于与搜索文档, ...

  7. odoo项目结构参数属性详解

    1.基础文件及目录结构 在认识odoo ORM框架前,先介绍一下odoo中模块目录结构.   data:存放模块预制数据i18n:存放国际化文件models:存放模型等py代码security:存放权 ...

  8. python2和python3的解释器安装

    python环境及安装 主板:人的骨架 用于扩展设备 CPU:人的大脑 用于计算和逻辑处理 硬板:肚子 存储数据(永久存储) C盘···· 内存:存储数据(临时储存) 没有保存会消失 电源:人的心脏 ...

  9. Vue+webpack项目的多环境打包配置

    背景:由于需要将应用部署到线上开发环境.线上测试环境.线上预发环境.线上生产环境,而每个环境的访问地址是不同的.如果每次更改请求地址未免有些繁琐,就考虑在本地进行一次性配置. 代码管理工具:git 代 ...

  10. JSON转换方法解析

    JSON.parse() 与 JSON.stringify() 的区别 JSON.parse() :是从一个字符串中解析出 json 对象 JSON.stringify():是从一个对象中解析出字符串 ...