Activiti(基础)

一. 工作流简述

1.1工作流是什么

工作流(Workflow),就是通过计算机对业务流程自动化执行管理。它主要解决的是“**使在多个参与者之间按照某种预定义的规则自动进行传递文档、信息或任务的过程,从而实现某个预期的业务目标,或者促使此目标的实现**”。工作流就是通过计算机技术对业务流程进行自动化管理。实现多个参与者按照预定的流程去自动执行业务流程。工作流管理系统的目标:管理工作的流程以确保工作在正确的时间被期望的人员所执行——在自动化进行的业务过程中插入人工的执行和干预。

1.2哪些行业需要工作流

消费品行业,制造业,电信服务业,银证险等金融服务业,物流服务业,物业服务业,物业管理,大中型进出口贸易公司,政府事业机构,研究院所及教育服务业等,特别是大的跨国企业和集团公司。

总结一句话:凡是有组织机构的公司都有可能用到工作流。

二 工作流系统的使用

1.关键业务流程:订单、报价处理、采购处理、合同审核、客户电话处理、供应链管理等

2.行政管理类:出差申请、加班申请、请假申请、用车申请、各种办公用品申请、购买申请、日报周报等凡是原来手工流转处理的行政表单。

3.人事管理类:员工培训安排、绩效考评、职位变动处理、员工档案信息管理等。

4.财务相关类:付款请求、应收款处理、日常报销处理、出差报销、预算和计划申请等。

5.客户服务类:客户信息管理、客户投诉、请求处理、售后服务管理等。

6.特殊服务类:ISO系列对应流程、质量管理对应流程、产品数据信息管理、贸易公司报关处理、物流公司货物跟踪处理等各种通过表单逐步手工流转完成的任务均可应用工作流软件自动规范地实施。

三 .常见的工作流框架

Activiti5.13、JBPM4.4、OSWorkFlow、WorkFlow......

工作流框架底层需要有数据库提供支持,activiti5.13版本,有23张表。JBPM4.4框架底层有数据库支持,18张表。JBPM底层使用hibernate操作数据库。Activiti框架底层使用的mybatis操作数据库。

四 .Activti的历史简介

Activiti项目是一项新的基于Apache许可的开源**BPM**平台,从基础开始构建,旨在提供支持新的**BPMN 2.0**标准,包括支持对象管理组(OMG),面对新技术的机遇,诸如互操作性和云架构,提供技术实现。

创始人Tom Baeyens是**JBoss** jBPM的项目架构师,以及另一位架构师Joram Barrez,一起加入到创建Alfresco这项首次实现Apache开源许可的BPMN 2.0引擎开发中来。Activiti前身是jbpm4,Activiti架构和jbpm4基本上是一样的。

架构师Tom Baeyens说:“Activiti有非常大的影响力来改变目前BPM的生态。Activiti的Apache授权,完整的功能,将使Activiti到达一个新的水平。Activiti将推动业界的创新,因为BPM技术可以广泛而自由地被应用。通过实现这些想法以及开源社区的努力,也让Activiti成为事实上的 BPM和BPMN标准执行“。它的特色是提供了eclipse插件,开发人员可以通过插件直接绘画出**业务流程图**。

五 重要的名词解释

5.1工作流引擎

**ProcessEngine**对象,这是Activiti工作的核心。负责生成流程运行时的各种实例及数据、监控和管理流程的运行,该对象是流程使用核心,通过该对象可以获得流程任务的相关对象

5.2 BPM

**BPM,即业务流程管理**,是一种以规范化的构造端到端的卓越业务流程为中心,以持续的提高组织业务绩效为目的的系统化方法,常见商业管理教育如EMBA、MBA等均将BPM包含在内。

5.3 BPMN

**BPMN:**业务流程建模与标注,包括这些图元如何组合成一个业务流程图(Business Process Diagram);讨论BPMN的各种的用途,包括以何种精度来影响一个流程图中的模型;BPMN作为一个标准的价值,以及BPMN未来发展的远景。

具体发展历史如下:

流对象:一个业务流程图有三个流对象的核心元素。

事件—一个事件用圆圈来描述,表示一个业务流程期间发生的东西。事件影响流程的流动,一般有一个原因(触发器)或一个影响(结果)。基于它们对流程的影响,有三种事件:开始,中间以及终止事件

活动:用圆角矩形表示,一个流程由一个活动或多个活动组成

**条件:**条件用熟悉的菱形表示,用于控制序列流的分支与合并。另外,它还可以作为传统的选择,还包括路径的分支与合并。其内部的标记会给出控制流的类型。

Activiti使用Bpmn2.0标准进行流程定义(流程建模),bpmn采用xml描述 。

如何使用bpmn进行流程建模:

通常情况下,使用建模工具进行流程图绘制,生成一个图形,通过工具查看bpmn的xml描述 。

如果熟练,手动编写pbmn的xml文档。(对坐标和结点的大小通过工具完成)

六 准备环境

6.1 Activiti软件环境

JDK1.6或者更高版本

支持的数据库有:h2,mysql,oracle,db2.......等

支持Activiti运行的jar包,可以通过**maven**依赖引入

6.2 相关资源下载

1)JDK可以到sun的官网下载

http://www.oracle.com/technetwork/java/javase/downloads/index.html

2)数据库,例如:mysql可以在官网上下载。

http://www.mysql.com

3)activiti也可以到Activiti官方网站下载得到。

http://activiti.org/download.html

6.3安装流程设计器(eclipse插件)

6.3.1安装方式一

在有网络的情况下,安装流程设计器步骤如下:

打开 Help -> Install New Software. 在如下面板中:

在如下Install界面板中,点击Add按钮:

配置新装插件的地址和名称

然后填入下列字段

Name: Activiti BPMN 2.0 designer

Location: http://activiti.org/designer/update/

回到Install界面,在面板正中列表中把所有展示出来的项目都勾上:

点击复选框

在Detail部分记得选中 “Contact all updates sites…” , 因为它会检查所有当前安装所需要的插件并可以被Eclipse下载.

安装完以后,点击新建工程new->Other…打开面板,如果看到下图内容:

说明安装成功了。

6.3.2安装方式二

在没有网络的情况下,安装流程设计器步骤如下:

第一步:获得插件的安装包

第二步:解压安装包,复制到eclipse中的dropins目录中

第三步:重启eclipse,点击新建工程new->Other…打开面板,如果看到下图内容:

说明安装成功了

6.4 idea插件

第一步:

点击FIile-Settings

第二步:点击Plusins 在右面的输入框中输入actiBPM

点击安装(这里由于我已经安装过嘞,所以没有显示),然后重启idea

第四步:

创建bpmn文件

6.5 准备开发环境

6.5.1了解activiti开发库

6.5.2 创建WEB工程,导入Activiti依赖包

在eclipse左边工作栏右键New选择创建Maven Project项目,创建一个名为ActivitiDemo的项目

点击Finish完成。

然后在pom.xml文件中添加以下依赖

<dependencies>

<!-- https://mvnrepository.com/artifact/org.activiti/activiti-engine -->

<dependency>

<groupId>org.activiti</groupId>

<artifactId>activiti-engine</artifactId>

<version>5.22.0</version>

</dependency>

<!-- https://mvnrepository.com/artifact/org.activiti/activiti-spring -->

<dependency>

<groupId>org.activiti</groupId>

<artifactId>activiti-spring</artifactId>

<version>5.22.0</version>

</dependency>

<dependency>

<groupId>org.codehaus.groovy</groupId>

<artifactId>groovy-all</artifactId>

<version>2.4.3</version>

</dependency>

<dependency>

<groupId>org.slf4j</groupId>

<artifactId>slf4j-api</artifactId>

<version>1.7.6</version>

</dependency>

<dependency>

<groupId>org.slf4j</groupId>

<artifactId>slf4j-jdk14</artifactId>

<version>1.7.6</version>

</dependency>

<!-- 单元测试 -->

<dependency>

<groupId>junit</groupId>

<artifactId>junit</artifactId>

<version>4.12</version>

<scope>test</scope>

</dependency>

<dependency>

<groupId>mysql</groupId>

<artifactId>mysql-connector-java</artifactId>

<version>5.1.38</version>

</dependency>

</dependencies>

<build>

<plugins>

<plugin>

<artifactId>maven-war-plugin</artifactId>

<configuration>

<version>3.1</version>

</configuration>

</plugin>

<!-- java编译插件 -->

<plugin>

<groupId>org.apache.maven.plugins</groupId>

<artifactId>maven-compiler-plugin</artifactId>

<version>2.3.2</version>

<configuration>

<source>1.7</source>

<target>1.7</target>

<encoding>UTF-8</encoding>

</configuration>

</plugin>

</plugins>

</build>

6.5.3初始化表结构

框架提供了和hibernate类似的自动建表功能

使用配置文件

要求配置文件名称必须为activiti-context.xml或者activiti.cfg.xml,配置的信息必须为

<beans xmlns="http://www.springframework.org/schema/beans"

xmlns:context="http://www.springframework.org/schema/context" xmlns:tx="http://www.springframework.org/schema/tx"

xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"

xsi:schemaLocation="http://www.springframework.org/schema/beans

http://www.springframework.org/schema/beans/spring-beans.xsd

http://www.springframework.org/schema/context

http://www.springframework.org/schema/context/spring-context-2.5.xsd

http://www.springframework.org/schema/tx

http://www.springframework.org/schema/tx/spring-tx-3.0.xsd">

<!-- 配置流程引擎配置对象 -->

<bean id="processEngineConfiguration"

class="org.activiti.engine.impl.cfg.StandaloneProcessEngineConfiguration">

<property name="jdbcDriver" value="com.mysql.jdbc.Driver" />

<property name="jdbcUrl" value="jdbc:mysql:///activitidb" />

<property name="jdbcUsername" value="root" />

<property name="jdbcPassword" value="123" />

<property name="databaseSchemaUpdate" value="true" />

</bean>

</beans>

@Test

public void createTable1(){

ProcessEngine processEngine = ProcessEngineConfiguration.createProcessEngineConfigurationFromResource("activiti-context.xml","processEngineConfiguration").buildProcessEngine();

System.out.println("------processEngine----:" + processEngine);

}

使用默认配置文件

<beans xmlns="http://www.springframework.org/schema/beans"

xmlns:context="http://www.springframework.org/schema/context" xmlns:tx="http://www.springframework.org/schema/tx"

xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"

xsi:schemaLocation="http://www.springframework.org/schema/beans

http://www.springframework.org/schema/beans/spring-beans.xsd

http://www.springframework.org/schema/context

http://www.springframework.org/schema/context/spring-context-2.5.xsd

http://www.springframework.org/schema/tx

http://www.springframework.org/schema/tx/spring-tx-3.0.xsd">

<!-- 配置流程引擎配置对象 -->

<bean id="processEngineConfiguration"

class="org.activiti.engine.impl.cfg.StandaloneProcessEngineConfiguration">

<property name="jdbcDriver" value="com.mysql.jdbc.Driver" />

<property name="jdbcUrl" value="jdbc:mysql:///activitidb" />

<property name="jdbcUsername" value="root" />

<property name="jdbcPassword" value="123" />

<property name="databaseSchemaUpdate" value="true" />

</bean>

<!-- 配置一个流程引擎工厂bean,用于创建流程引擎对象 -->

<bean id="processEngine" class="org.activiti.spring.ProcessEngineFactoryBean">

<!-- 通过set方法注入流程引擎配置对象 -->

<property name="processEngineConfiguration" ref="processEngineConfiguration" />

</bean>

</beans>

@Test

public void createTable2(){

ProcessEngine processEngine = ProcessEngines.getDefaultProcessEngine();

System.out.println(processEngine);

}

然后运行该测试方法,如果运行成功,在数据库中应该会产生25张Activiti的相关数据表

6.5.4 Activiti表说明

下面是概括了几个常用的数据表

Activiti的后台是有数据库的支持,所有的表都以ACT_开头。 第二部分是表示表的用途的两个字母标识。 用途也和服务的API对应。

ACT_RE_*: ‘RE’表示repository。 这个前缀的表包含了流程定义和流程静态资源 (图片,规则,等等)。

ACT_RU_*: ‘RU’表示runtime。 这些运行时的表,包含流程实例,任务,变量,异步任务,等运行中的数据。 Activiti只在流程实例执行过程中保存这些数据, 在流程结束时就会删除这些记录。 这样运行时表可以一直很小速度很快。

ACT_ID_*: ‘ID’表示identity。 这些表包含身份信息,比如用户,组等等。

ACT_HI_*: ‘HI’表示history。 这些表包含历史数据,比如历史流程实例, 变量,任务等等。

ACT_GE_*: 通用数据, 用于不同场景下。

Ø 流程部署相关表

act_re_deployement 部署对象表

act_rep_procdef 流程定义表

act_ge_bytearray 资源文件表

act_ge_prperty 主键生成策略表(对于部署对象表的主键ID)

Ø 流程实例相关表

act_ru_execution 正在执行的执行对象表(包含执行对象ID和流程实例ID,如果有多个线程可能流程实例ID不一样)

act_hi_procinst 流程实例历史表

act_hi_actinst 存放历史所有完成的任务

Ø Task 任务相关表

act_ru_task 代办任务表 (只对应节点是UserTask的)

act_hi_taskinst 代办任务历史表 (只对应节点是UserTask的)

act_hi_actinst 所有节点活动历史表 (对应流程的所有节点的活动历史,从开始节点一直到结束节点中间的所有节点的活动都会被记录)

Ø 流程变量表

act_ru_variable 正在执行的流程变量表

act_hi_variable 流程变量历史表

七.核心API

7.1 ProcessEngine

说明:

在Activiti中最核心的类,其他的类都是由他而来。

产生方式

ProcessEngine processEngine = ProcessEngines.getDefaultProcessEngine();

3)可以产生RepositoryService

RepositoryService repositoryService =processEngine.getRepositoryService();

可以产生 RuntimeService

RuntimeService runtimeService = processEngine.getRuntimeService();

可以产生TaskService

TaskService taskService =processEngine.getTaskService();

各个Service的作用

RepositoryService管理流程定义

RuntimeService执行管理,包括启动,推进,删除流程实例等操作

TaskService任务管理

7.2 RepositoryService

Activiti的仓库服务类。所谓的仓库指流程定义文档的两个文件:bpmn文件和流程图片

该service可以用来删除部署的流程定义。

7.3 RuntimeService

是Activiti的流程执行服务类,可以从这个服务类中获取很多关于流程执行的相关的信息。

7.4 TaskService

是Activiti的任务服务类。可以从这个类中获取任务的相关信息,如当前正在执行的个人待办和用户组待办任务。

7.5 HistoryService

是Activiti的查询历史信息的类,在一个流程执行完成后,这个对象为我们提供查询历史信息,可以跟踪流程实例对应所有待办节点的运行情况。

7.6 ProcessDefinition

流程定义类,可以从这里获得资源文件等。

7.7 ProcessInstance

代表流程定义的执行实例,当一个部署的流程图启动后,该流程只有一条流程实例数据,但是它的流程任务可以有多个,每个任务对应流程图中相应的流程节点。

八 入门HelloWorld程序

8.1创建流程图方法

点击ActivitiTest项目,在src/main/java目录下创建一个diagrams目录用来存放流程图

在当前项目右键选择Activiti Diagram流程图输入流程图名称HelloWorld,然后点击OK

在控制面板的右边栏有相关的画图图标操作

其中一个流程必须包含一个开始节点和一个结束节点,结束节点可以有多个。

然后使用StartEvent, UserTask,EndEvent画出下面的流程图,然后用Connection中的SequenceFlow连线连接起来。

8.2创建流程图,如下图

8.3 指定流程图名称,ID和UserTask的处理人

1)选中第一个节点,在 General中的name属性中输入当前节点的名称,在Main config中的Assignee中输入该节点的处理人,然后以此类推将3个节点的值设置完成。

![1542677483179](/1542677483179.png)

2)然后在流程图旁边的空白出点击一下,输入流程的ID和Name值,然后保存

8.4 将流程图部署到Activiti的数据表中

/**

* 部署流程定义(操作数据表:act_re_deployment、act_re_procdef、act_ge_bytearray)

*/

@Test

public void test1(){

ProcessEngine processEngine = ProcessEngines.getDefaultProcessEngine();

RepositoryService service = processEngine.getRepositoryService();

Deployment deployment = service.createDeployment()

.name("helloworld入门")

.addClasspathResource("diagrams/HelloWorld.bpmn")

.addClasspathResource("diagrams/HelloWorld.png")

.deploy();

System.out.println(deployment.getId());

System.out.println(deployment.getName());

}

8.5 查询流程定义列表

/**

* 查询流程定义列表

*/

@Test

public void test2() {

// 流程定义查询对象,用于查询表act_re_procdef

ProcessDefinitionQuery query = processEngine.getRepositoryService().createProcessDefinitionQuery();

// 添加过滤条件

query.processDefinitionKey(“HelloWorldKsy”);

// 添加排序条件

query.orderByProcessDefinitionVersion().desc();

// 添加分页查询

query.listPage(0, 10);

List list = query.list();

for (ProcessDefinition pd : list) {

System.out.println(pd.getId() + “–” + pd.getName());

}

}

8.6 启动流程实例

其中runtimeService.startProcessInstanceByKey(“HelloWorldKey”);中的HelloWorldKey对应流程图中的ID值,在数据表中对应act_re_procdef流程定义表中的key字段

@Test

public void flowStart(){

String processDefinitionKey = "HelloWorldKsy";

//获取正在执行流程实例和执行对象相关的service

RuntimeService runtimeService = processEngine.getRuntimeService();

//使用流程定义key启动流程实例,key对象是HelloWorld.bpmn文件中的ID属性值,对应的是act_re_procdef表中的key

ProcessInstance processInstance = runtimeService.startProcessInstanceByKey(processDefinitionKey);

System.out.println(processInstance.getId()); //流程实例ID

}

启动完流程后在act_ru_execution表中会产生一条数据,这条数据为当前流程正在执行的任务,其中act_id_字段的值对应流程图节点的ID值

在act_ru_task表中会产生一条任务数据,execution_id_对应act_ru_execution主键,proc_inst_id_为流程实例ID,name_值为流程节点名称,assignee_字段为该待办当前的处理

8.7 查询待办任务

/**

* 查询个人任务列表

*/

@Test

public void test7() {

TaskQuery query = processEngine.getTaskService().createTaskQuery();

String assignee = "张三";

query.taskAssignee(assignee);

List<Task> list = query.list();

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());

}

}

8.8 完成待办任务

/**

* 办理任务

*/

@Test

public void test8(){

String taskId= "7504";

processEngine.getTaskService().complete(taskId);

System.out.println("办理完成,任务ID是:"+taskId);

}

其中taskId对应act_ru_task表的主键ID,因为当前待办任务为第一个节点提交申请,当执行完这个待办后下一条待办数据将会流转到审批【部门经理】那,然后以此类推可以将部门经理和总经理的待办任务全部查询和执行完成。

8.9小结

Activiti框架提供的Service对象

RepositoryService----操作静态的资源(流程定义,bpmn、png)

RuntimeService-----操作流程实例(启动流程实例、查询流程实例、结束流程实例)

TaskService-----操作任务(查询任务、办理任务)

HistoryService----操作历史数据

Activiti框架提供的对象(和表有对应关系)

Deployment-----act_re_deployment

ProcessDefinition----act_re_procdef

ProcessInstance-----act_ru_execution

Task-----act_ru_task

九 Activiti详细的API

9.1部署流程定义

/**

* 部署流程定义 方式一:读取单个的流程定义文件 方式二:读取zip压缩文件

*/

@Test

public void test1() {

DeploymentBuilder deploymentBuilder = processEngine.getRepositoryService().createDeployment();

// 方式一:读取单个的流程定义文件

/*

deploymentBuilder.addClasspathResource("test1.bpmn");

deploymentBuilder.addClasspathResource("test1.png");

Deployment deployment = deploymentBuilder.deploy();

*/

// 方式二:读取zip压缩文件

ZipInputStream zipInputStream = new ZipInputStream(this.getClass().getClassLoader().getResourceAsStream("process.zip"));

deploymentBuilder.addZipInputStream(zipInputStream);

deploymentBuilder.name("请假流程部署");

Deployment deployment = deploymentBuilder.deploy();

}

9.2 查询部署列表

/**

* 查询部署列表

*/

@Test

public void test2() {

// 部署查询对象,查询表act_re_deployment

DeploymentQuery query = processEngine.getRepositoryService().createDeploymentQuery();

List<Deployment> list = query.list();

for (Deployment deployment : list) {

String id = deployment.getId();

String name = deployment.getName();

System.out.println(id+"---"+name);

}

}

9.3查询定义列表

/**

* 查询流程定义列表

*/

@Test

public void test3() {

// 流程定义查询对象,查询表act_re_procdef

ProcessDefinitionQuery query = processEngine.getRepositoryService().createProcessDefinitionQuery();

List<ProcessDefinition> list = query.list();

for (ProcessDefinition pd : list) {

String deploymentId = pd.getDeploymentId();

System.out.println(pd.getName() + "" + pd.getId()+"部署ID:"+deploymentId);

}

}

9.4 删除部署信息

/**

* 删除部署信息

*/

@Test

public void test4() {

String deploymentId = "1";

// processEngine.getRepositoryService().deleteDeployment(deploymentId);

processEngine.getRepositoryService().deleteDeployment(deploymentId, true); //级联删除

}

9.5 删除流程定义

/**

* 删除流程定义(通过删除部署信息达到删除流程定义的目的)

*/

@Test

public void test5() {

String deploymentId = "22501";

// processEngine.getRepositoryService().deleteDeployment(deploymentId);

processEngine.getRepositoryService().deleteDeployment(deploymentId,true);

}

9.6 查询部署对应的文件流

/**

* 查询一次部署对应的流程定义文件名称和对应的输入流(bpmn png)

*/

@Test

public void test6() throws Exception {

String deploymentId = "20001";

List<String> names = processEngine.getRepositoryService().getDeploymentResourceNames(deploymentId);

for (String name : names) {

System.out.println(name);

InputStream in = processEngine.getRepositoryService().getResourceAsStream(deploymentId, name);

// 将文件保存到本地磁盘

File file = new File("d:\\" + name);

File f1=new File( file.getParent());

if(f1.exists()==false){

f1.mkdirs();

}

OutputStream out = new FileOutputStream(file);

byte[] b = new byte[1024];

int len = 0;

while ((len = in.read(b)) != -1) {

out.write(b, 0, len);

}

out.close();

in.close();

}

}

<dependency>

<groupId>commons-io</groupId>

<artifactId>commons-io</artifactId>

<version>2.4</version>

</dependency>

/**

* 查询一次部署对应的流程定义文件名称和对应的输入流(bpmn png)

*/

@Test

public void test6_1() throws Exception {

String deploymentId = "20001";

List<String> names = processEngine.getRepositoryService().getDeploymentResourceNames(deploymentId);

for (String name : names) {

System.out.println(name);

InputStream in = processEngine.getRepositoryService().getResourceAsStream(deploymentId, name);

// 将文件保存到本地磁盘

File file = new File("d:\\" + name);

File f1=new File( file.getParent());

if(f1.exists()==false){

f1.mkdirs();

}

FileUtils.copyInputStreamToFile(in, new File("d:\\" + name));

in.close();

}

}

9.7 获取PNG文件输入流

/**

* 获得png文件的输入流

*/

@Test

public void test7() throws Exception {

String processDefinitionId = "HelloWorldKsy:2:2504";

InputStream pngInputStream = processEngine.getRepositoryService().getProcessDiagram(processDefinitionId);

FileUtils.copyInputStreamToFile(pngInputStream, new File("d:\\my.png"));

}

9.8 启动流程定义2种方式

/**

* 启动流程实例 方式一:根据流程定义的id启动 方式二:根据流程定义的key启动(自动选择最新版本的流程定义启动流程实例)

*/

@Test

public void test8() {

/*

* String processDefinitionId = "HelloWorldKsy:2:2504"; ProcessInstance

* processInstance =

* processEngine.getRuntimeService().startProcessInstanceById

* (processDefinitionId ); System.out.println(processInstance.getId());

*/

String processDefinitionKey = "HelloWorldKsy";

ProcessInstance processInstance = processEngine.getRuntimeService().startProcessInstanceByKey(processDefinitionKey);

System.out.println(processInstance.getId());

}

根据Key启动流程,会使用最新的的流程定义的Key。选择最新的流程定义进行启动!

9.9 查询流程实例列表

/**

* 查询流程实例列表,查询act_ru_execution表

*/

@Test

public void test9(){

//流程实例查询对象,查询act_ru_execution表

ProcessInstanceQuery query = processEngine.getRuntimeService().createProcessInstanceQuery();

query.processDefinitionKey("HelloWorldKsy");

query.orderByProcessInstanceId().desc();

query.listPage(0, 2);

List<ProcessInstance> list = query.list();

for (ProcessInstance pi : list) {

System.out.println(pi.getId() + " " + pi.getActivityId());

}

}

9.10 结束流程实例

/**

* 结束流程实例,操作的表act_ru_execution act_ru_task

*/

@Test

public void test10(){

String processInstanceId = "10001";

processEngine.getRuntimeService().deleteProcessInstance(processInstanceId , "我愿意");

}

9.11 查询任务列表

/**

* 查询任务列表

*/

@Test

public void test11() {

// 任务查询对象,查询act_ru_task表

TaskQuery query = processEngine.getTaskService().createTaskQuery();

String assignee = "张三";

query.taskAssignee(assignee);

query.orderByTaskCreateTime().desc();

List<Task> list = query.list();

for (Task task : list) {

System.out.println(task.getId());

}

}

9.12 查询任务列表

/**

* 办理任务

*/

@Test

public void test12(){

String taskId = "32504";

processEngine.getTaskService().complete(taskId);

}

9.13 查询最新版本的流程定义列表

/**

* 查询最新版本的流程定义列表

*/

@Test

public void test14() {

ProcessDefinitionQuery query = processEngine.getRepositoryService().createProcessDefinitionQuery();

query.orderByProcessDefinitionVersion().asc();

List<ProcessDefinition> list = query.list();

Map<String, ProcessDefinition> map = new HashMap<String, ProcessDefinition>();

for (ProcessDefinition pd : list) {

map.put(pd.getKey(), pd);

}

ArrayList<ProcessDefinition> lastList = new ArrayList<>(map.values());

for (ProcessDefinition processDefinition : lastList) {

System.out.println(processDefinition.getName() + "  " + processDefinition.getVersion());

}

}

Activiti(基础)一. 工作流简述1.1工作流是什么工作流(Workflow),就是通过计算机对业务流程自动化执行管理。它主要解决的是“**使在多个参与者之间按照某种预定义的规则自动进行传递文档、信息或任务的过程,从而实现某个预期的业务目标,或者促使此目标的实现**”。工作流就是通过计算机技术对业务流程进行自动化管理。实现多个参与者按照预定的流程去自动执行业务流程。工作流管理系统的目标:管理工作的流程以确保工作在正确的时间被期望的人员所执行——在自动化进行的业务过程中插入人工的执行和干预。1

1.2哪些行业需要工作流消费品行业,制造业,电信服务业,银证险等金融服务业,物流服务业,物业服务业,物业管理,大中型进出口贸易公司,政府事业机构,研究院所及教育服务业等,特别是大的跨国企业和集团公司。
总结一句话:凡是有组织机构的公司都有可能用到工作流。123二 工作流系统的使用关键业务流程:订单、报价处理、采购处理、合同审核、客户电话处理、供应链管理等
行政管理类:出差申请、加班申请、请假申请、用车申请、各种办公用品申请、购买申请、日报周报等凡是原来手工流转处理的行政表单。
人事管理类:员工培训安排、绩效考评、职位变动处理、员工档案信息管理等。
财务相关类:付款请求、应收款处理、日常报销处理、出差报销、预算和计划申请等。
客户服务类:客户信息管理、客户投诉、请求处理、售后服务管理等。
特殊服务类:ISO系列对应流程、质量管理对应流程、产品数据信息管理、贸易公司报关处理、物流公司货物跟踪处理等各种通过表单逐步手工流转完成的任务均可应用工作流软件自动规范地实施。
三 .常见的工作流框架Activiti5.13、JBPM4.4、OSWorkFlow、WorkFlow......工作流框架底层需要有数据库提供支持,activiti5.13版本,有23张表。JBPM4.4框架底层有数据库支持,18张表。JBPM底层使用hibernate操作数据库。Activiti框架底层使用的mybatis操作数据库。12四 .Activti的历史简介Activiti项目是一项新的基于Apache许可的开源**BPM**平台,从基础开始构建,旨在提供支持新的**BPMN 2.0**标准,包括支持对象管理组(OMG),面对新技术的机遇,诸如互操作性和云架构,提供技术实现。
创始人Tom Baeyens是**JBoss** jBPM的项目架构师,以及另一位架构师Joram Barrez,一起加入到创建Alfresco这项首次实现Apache开源许可的BPMN 2.0引擎开发中来。Activiti前身是jbpm4,Activiti架构和jbpm4基本上是一样的。
架构师Tom Baeyens说:“Activiti有非常大的影响力来改变目前BPM的生态。Activiti的Apache授权,完整的功能,将使Activiti到达一个新的水平。Activiti将推动业界的创新,因为BPM技术可以广泛而自由地被应用。通过实现这些想法以及开源社区的努力,也让Activiti成为事实上的 BPM和BPMN标准执行“。它的特色是提供了eclipse插件,开发人员可以通过插件直接绘画出**业务流程图**。12345五 重要的名词解释5.1工作流引擎**ProcessEngine**对象,这是Activiti工作的核心。负责生成流程运行时的各种实例及数据、监控和管理流程的运行,该对象是流程使用核心,通过该对象可以获得流程任务的相关对象15.2 BPM**BPM,即业务流程管理**,是一种以规范化的构造端到端的卓越业务流程为中心,以持续的提高组织业务绩效为目的的系统化方法,常见商业管理教育如EMBA、MBA等均将BPM包含在内。15.3 BPMN**BPMN:**业务流程建模与标注,包括这些图元如何组合成一个业务流程图(Business Process Diagram);讨论BPMN的各种的用途,包括以何种精度来影响一个流程图中的模型;BPMN作为一个标准的价值,以及BPMN未来发展的远景。
具体发展历史如下:123

流对象:一个业务流程图有三个流对象的核心元素。
事件—一个事件用圆圈来描述,表示一个业务流程期间发生的东西。事件影响流程的流动,一般有一个原因(触发器)或一个影响(结果)。基于它们对流程的影响,有三种事件:开始,中间以及终止事件

活动:用圆角矩形表示,一个流程由一个活动或多个活动组成

**条件:**条件用熟悉的菱形表示,用于控制序列流的分支与合并。另外,它还可以作为传统的选择,还包括路径的分支与合并。其内部的标记会给出控制流的类型。

Activiti使用Bpmn2.0标准进行流程定义(流程建模),bpmn采用xml描述 。

如何使用bpmn进行流程建模:通常情况下,使用建模工具进行流程图绘制,生成一个图形,通过工具查看bpmn的xml描述 。如果熟练,手动编写pbmn的xml文档。(对坐标和结点的大小通过工具完成)
六 准备环境6.1 Activiti软件环境   JDK1.6或者更高版本1   支持的数据库有:h2,mysql,oracle,db2.......等1   支持Activiti运行的jar包,可以通过**maven**依赖引入16.2 相关资源下载1)JDK可以到sun的官网下载
http://www.oracle.com/technetwork/java/javase/downloads/index.html

2)数据库,例如:mysql可以在官网上下载。
http://www.mysql.com
3)activiti也可以到Activiti官方网站下载得到。
http://activiti.org/download.html
6.3安装流程设计器(eclipse插件)6.3.1安装方式一在有网络的情况下,安装流程设计器步骤如下:
打开 Help -> Install New Software. 在如下面板中:

在如下Install界面板中,点击Add按钮:

配置新装插件的地址和名称
然后填入下列字段Name: Activiti BPMN 2.0 designerLocation: http://activiti.org/designer/update/12

回到Install界面,在面板正中列表中把所有展示出来的项目都勾上:

点击复选框
在Detail部分记得选中 “Contact all updates sites…” , 因为它会检查所有当前安装所需要的插件并可以被Eclipse下载.
安装完以后,点击新建工程new->Other…打开面板,如果看到下图内容:

说明安装成功了。
6.3.2安装方式二在没有网络的情况下,安装流程设计器步骤如下:
第一步:获得插件的安装包

第二步:解压安装包,复制到eclipse中的dropins目录中

第三步:重启eclipse,点击新建工程new->Other…打开面板,如果看到下图内容:

说明安装成功了
6.4 idea插件第一步:
点击FIile-Settings

第二步:点击Plusins 在右面的输入框中输入actiBPM

点击安装(这里由于我已经安装过嘞,所以没有显示),然后重启idea
第四步:
创建bpmn文件

6.5 准备开发环境6.5.1了解activiti开发库

6.5.2 创建WEB工程,导入Activiti依赖包在eclipse左边工作栏右键New选择创建Maven Project项目,创建一个名为ActivitiDemo的项目

点击Finish完成。
然后在pom.xml文件中添加以下依赖
<dependencies>
<!-- https://mvnrepository.com/artifact/org.activiti/activiti-engine --><dependency><groupId>org.activiti</groupId><artifactId>activiti-engine</artifactId><version>5.22.0</version></dependency>
<!-- https://mvnrepository.com/artifact/org.activiti/activiti-spring --><dependency><groupId>org.activiti</groupId><artifactId>activiti-spring</artifactId><version>5.22.0</version></dependency>
<dependency><groupId>org.codehaus.groovy</groupId><artifactId>groovy-all</artifactId><version>2.4.3</version></dependency>
<dependency><groupId>org.slf4j</groupId><artifactId>slf4j-api</artifactId><version>1.7.6</version></dependency>
<dependency><groupId>org.slf4j</groupId><artifactId>slf4j-jdk14</artifactId><version>1.7.6</version></dependency>
<!-- 单元测试 --><dependency><groupId>junit</groupId><artifactId>junit</artifactId><version>4.12</version><scope>test</scope></dependency>
<dependency><groupId>mysql</groupId><artifactId>mysql-connector-java</artifactId><version>5.1.38</version></dependency></dependencies>
<build><plugins><plugin><artifactId>maven-war-plugin</artifactId><configuration><version>3.1</version></configuration></plugin><!-- java编译插件 --><plugin><groupId>org.apache.maven.plugins</groupId><artifactId>maven-compiler-plugin</artifactId><version>2.3.2</version><configuration><source>1.7</source><target>1.7</target><encoding>UTF-8</encoding></configuration></plugin></plugins></build>
12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970716.5.3初始化表结构框架提供了和hibernate类似的自动建表功能
使用配置文件

要求配置文件名称必须为activiti-context.xml或者activiti.cfg.xml,配置的信息必须为
<beans xmlns="http://www.springframework.org/schema/beans"xmlns:context="http://www.springframework.org/schema/context" xmlns:tx="http://www.springframework.org/schema/tx"xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsdhttp://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context-2.5.xsdhttp://www.springframework.org/schema/tx http://www.springframework.org/schema/tx/spring-tx-3.0.xsd"><!-- 配置流程引擎配置对象 --><bean id="processEngineConfiguration"class="org.activiti.engine.impl.cfg.StandaloneProcessEngineConfiguration"><property name="jdbcDriver" value="com.mysql.jdbc.Driver" /><property name="jdbcUrl" value="jdbc:mysql:///activitidb" /><property name="jdbcUsername" value="root" /><property name="jdbcPassword" value="123" /><property name="databaseSchemaUpdate" value="true" /></bean></beans>
[email protected] void createTable1(){ProcessEngine processEngine = ProcessEngineConfiguration.createProcessEngineConfigurationFromResource("activiti-context.xml","processEngineConfiguration").buildProcessEngine();System.out.println("------processEngine----:" + processEngine); }
123456使用默认配置文件
<beans xmlns="http://www.springframework.org/schema/beans"xmlns:context="http://www.springframework.org/schema/context" xmlns:tx="http://www.springframework.org/schema/tx"xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsdhttp://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context-2.5.xsdhttp://www.springframework.org/schema/tx http://www.springframework.org/schema/tx/spring-tx-3.0.xsd"><!-- 配置流程引擎配置对象 --><bean id="processEngineConfiguration"class="org.activiti.engine.impl.cfg.StandaloneProcessEngineConfiguration"><property name="jdbcDriver" value="com.mysql.jdbc.Driver" /><property name="jdbcUrl" value="jdbc:mysql:///activitidb" /><property name="jdbcUsername" value="root" /><property name="jdbcPassword" value="123" /><property name="databaseSchemaUpdate" value="true" /></bean>
<!-- 配置一个流程引擎工厂bean,用于创建流程引擎对象 --><bean id="processEngine" class="org.activiti.spring.ProcessEngineFactoryBean"><!-- 通过set方法注入流程引擎配置对象 --><property name="processEngineConfiguration" ref="processEngineConfiguration" /></bean></beans>
[email protected] void createTable2(){ProcessEngine processEngine = ProcessEngines.getDefaultProcessEngine();System.out.println(processEngine);}
123456然后运行该测试方法,如果运行成功,在数据库中应该会产生25张Activiti的相关数据表

6.5.4 Activiti表说明下面是概括了几个常用的数据表
Activiti的后台是有数据库的支持,所有的表都以ACT_开头。 第二部分是表示表的用途的两个字母标识。 用途也和服务的API对应。
ACT_RE_*: ‘RE’表示repository。 这个前缀的表包含了流程定义和流程静态资源 (图片,规则,等等)。ACT_RU_*: ‘RU’表示runtime。 这些运行时的表,包含流程实例,任务,变量,异步任务,等运行中的数据。 Activiti只在流程实例执行过程中保存这些数据, 在流程结束时就会删除这些记录。 这样运行时表可以一直很小速度很快。ACT_ID_*: ‘ID’表示identity。 这些表包含身份信息,比如用户,组等等。ACT_HI_*: ‘HI’表示history。 这些表包含历史数据,比如历史流程实例, 变量,任务等等。ACT_GE_*: 通用数据, 用于不同场景下。Ø 流程部署相关表
act_re_deployement 部署对象表act_rep_procdef 流程定义表act_ge_bytearray 资源文件表act_ge_prperty 主键生成策略表(对于部署对象表的主键ID)Ø 流程实例相关表
act_ru_execution 正在执行的执行对象表(包含执行对象ID和流程实例ID,如果有多个线程可能流程实例ID不一样)act_hi_procinst 流程实例历史表act_hi_actinst 存放历史所有完成的任务Ø Task 任务相关表
act_ru_task 代办任务表 (只对应节点是UserTask的)act_hi_taskinst 代办任务历史表 (只对应节点是UserTask的)act_hi_actinst 所有节点活动历史表 (对应流程的所有节点的活动历史,从开始节点一直到结束节点中间的所有节点的活动都会被记录)Ø 流程变量表
act_ru_variable 正在执行的流程变量表act_hi_variable 流程变量历史表七.核心API7.1 ProcessEngine说明:
在Activiti中最核心的类,其他的类都是由他而来。
产生方式
ProcessEngine processEngine = ProcessEngines.getDefaultProcessEngine();
3)可以产生RepositoryService
RepositoryService repositoryService =processEngine.getRepositoryService();
可以产生 RuntimeServiceRuntimeService runtimeService = processEngine.getRuntimeService();
可以产生TaskServiceTaskService taskService =processEngine.getTaskService();
各个Service的作用
RepositoryService管理流程定义RuntimeService执行管理,包括启动,推进,删除流程实例等操作TaskService任务管理7.2 RepositoryServiceActiviti的仓库服务类。所谓的仓库指流程定义文档的两个文件:bpmn文件和流程图片
该service可以用来删除部署的流程定义。
7.3 RuntimeService是Activiti的流程执行服务类,可以从这个服务类中获取很多关于流程执行的相关的信息。
7.4 TaskService是Activiti的任务服务类。可以从这个类中获取任务的相关信息,如当前正在执行的个人待办和用户组待办任务。
7.5 HistoryService是Activiti的查询历史信息的类,在一个流程执行完成后,这个对象为我们提供查询历史信息,可以跟踪流程实例对应所有待办节点的运行情况。
7.6 ProcessDefinition流程定义类,可以从这里获得资源文件等。
7.7 ProcessInstance
代表流程定义的执行实例,当一个部署的流程图启动后,该流程只有一条流程实例数据,但是它的流程任务可以有多个,每个任务对应流程图中相应的流程节点。
八 入门HelloWorld程序8.1创建流程图方法点击ActivitiTest项目,在src/main/java目录下创建一个diagrams目录用来存放流程图在当前项目右键选择Activiti Diagram流程图输入流程图名称HelloWorld,然后点击OK

在控制面板的右边栏有相关的画图图标操作
其中一个流程必须包含一个开始节点和一个结束节点,结束节点可以有多个。然后使用StartEvent, UserTask,EndEvent画出下面的流程图,然后用Connection中的SequenceFlow连线连接起来。
8.2创建流程图,如下图

8.3 指定流程图名称,ID和UserTask的处理人1)选中第一个节点,在 General中的name属性中输入当前节点的名称,在Main config中的Assignee中输入该节点的处理人,然后以此类推将3个节点的值设置完成。
![1542677483179](/1542677483179.png)1

2)然后在流程图旁边的空白出点击一下,输入流程的ID和Name值,然后保存

8.4 将流程图部署到Activiti的数据表中/** * 部署流程定义(操作数据表:act_re_deployment、act_re_procdef、act_ge_bytearray) */@Testpublic void test1(){ProcessEngine processEngine = ProcessEngines.getDefaultProcessEngine();RepositoryService service = processEngine.getRepositoryService();Deployment deployment = service.createDeployment().name("helloworld入门").addClasspathResource("diagrams/HelloWorld.bpmn").addClasspathResource("diagrams/HelloWorld.png").deploy();System.out.println(deployment.getId());System.out.println(deployment.getName());}1234567891011121314158.5 查询流程定义列表/*** 查询流程定义列表*/@Testpublic void test2() {// 流程定义查询对象,用于查询表act_re_procdefProcessDefinitionQuery query = processEngine.getRepositoryService().createProcessDefinitionQuery();// 添加过滤条件query.processDefinitionKey(“HelloWorldKsy”);// 添加排序条件query.orderByProcessDefinitionVersion().desc();// 添加分页查询query.listPage(0, 10);List list = query.list();for (ProcessDefinition pd : list) {System.out.println(pd.getId() + “–” + pd.getName());}}
8.6 启动流程实例其中runtimeService.startProcessInstanceByKey(“HelloWorldKey”);中的HelloWorldKey对应流程图中的ID值,在数据表中对应act_re_procdef流程定义表中的key字段
@Testpublic void flowStart(){String processDefinitionKey = "HelloWorldKsy";//获取正在执行流程实例和执行对象相关的serviceRuntimeService runtimeService = processEngine.getRuntimeService();//使用流程定义key启动流程实例,key对象是HelloWorld.bpmn文件中的ID属性值,对应的是act_re_procdef表中的keyProcessInstance processInstance = runtimeService.startProcessInstanceByKey(processDefinitionKey);System.out.println(processInstance.getId()); //流程实例ID}123456789启动完流程后在act_ru_execution表中会产生一条数据,这条数据为当前流程正在执行的任务,其中act_id_字段的值对应流程图节点的ID值
在act_ru_task表中会产生一条任务数据,execution_id_对应act_ru_execution主键,proc_inst_id_为流程实例ID,name_值为流程节点名称,assignee_字段为该待办当前的处理
8.7 查询待办任务/** * 查询个人任务列表 */@Testpublic void test7() {TaskQuery query = processEngine.getTaskService().createTaskQuery();String assignee = "张三";query.taskAssignee(assignee);List<Task> list = query.list();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());}}123456789101112131415161718198.8 完成待办任务/**
 * 办理任务 */@Testpublic void test8(){String taskId= "7504";processEngine.getTaskService().complete(taskId);System.out.println("办理完成,任务ID是:"+taskId);}12345678910其中taskId对应act_ru_task表的主键ID,因为当前待办任务为第一个节点提交申请,当执行完这个待办后下一条待办数据将会流转到审批【部门经理】那,然后以此类推可以将部门经理和总经理的待办任务全部查询和执行完成。
8.9小结Activiti框架提供的Service对象
RepositoryService----操作静态的资源(流程定义,bpmn、png)RuntimeService-----操作流程实例(启动流程实例、查询流程实例、结束流程实例)TaskService-----操作任务(查询任务、办理任务)HistoryService----操作历史数据Activiti框架提供的对象(和表有对应关系)
Deployment-----act_re_deploymentProcessDefinition----act_re_procdefProcessInstance-----act_ru_executionTask-----act_ru_task九 Activiti详细的API9.1部署流程定义/** * 部署流程定义 方式一:读取单个的流程定义文件 方式二:读取zip压缩文件 */@Testpublic void test1() {DeploymentBuilder deploymentBuilder = processEngine.getRepositoryService().createDeployment();
// 方式一:读取单个的流程定义文件/*deploymentBuilder.addClasspathResource("test1.bpmn");deploymentBuilder.addClasspathResource("test1.png"); Deployment deployment = deploymentBuilder.deploy();*/
// 方式二:读取zip压缩文件ZipInputStream zipInputStream = new ZipInputStream(this.getClass().getClassLoader().getResourceAsStream("process.zip"));deploymentBuilder.addZipInputStream(zipInputStream);deploymentBuilder.name("请假流程部署");Deployment deployment = deploymentBuilder.deploy();}

123456789101112131415161718192021229.2 查询部署列表/** * 查询部署列表 */@Testpublic void test2() {// 部署查询对象,查询表act_re_deploymentDeploymentQuery query = processEngine.getRepositoryService().createDeploymentQuery();List<Deployment> list = query.list();for (Deployment deployment : list) {String id = deployment.getId();String name = deployment.getName();System.out.println(id+"---"+name);}}
1234567891011121314159.3查询定义列表/** * 查询流程定义列表 */@Testpublic void test3() {// 流程定义查询对象,查询表act_re_procdefProcessDefinitionQuery query = processEngine.getRepositoryService().createProcessDefinitionQuery();List<ProcessDefinition> list = query.list();for (ProcessDefinition pd : list) {String deploymentId = pd.getDeploymentId();System.out.println(pd.getName() + "" + pd.getId()+"部署ID:"+deploymentId);}}
12345678910111213149.4 删除部署信息/** * 删除部署信息 */@Testpublic void test4() {String deploymentId = "1";// processEngine.getRepositoryService().deleteDeployment(deploymentId);processEngine.getRepositoryService().deleteDeployment(deploymentId, true); //级联删除}
123456789109.5 删除流程定义/** * 删除流程定义(通过删除部署信息达到删除流程定义的目的) */@Testpublic void test5() {String deploymentId = "22501";// processEngine.getRepositoryService().deleteDeployment(deploymentId);processEngine.getRepositoryService().deleteDeployment(deploymentId,true);}
123456789109.6 查询部署对应的文件流/** * 查询一次部署对应的流程定义文件名称和对应的输入流(bpmn png) */@Testpublic void test6() throws Exception {String deploymentId = "20001";List<String> names = processEngine.getRepositoryService().getDeploymentResourceNames(deploymentId);for (String name : names) {System.out.println(name);InputStream in = processEngine.getRepositoryService().getResourceAsStream(deploymentId, name);// 将文件保存到本地磁盘File file = new File("d:\\" + name);File f1=new File( file.getParent());if(f1.exists()==false){f1.mkdirs();}OutputStream out = new FileOutputStream(file);byte[] b = new byte[1024];int len = 0;while ((len = in.read(b)) != -1) {out.write(b, 0, len);}out.close();in.close();}}
123456789101112131415161718192021222324252627<dependency><groupId>commons-io</groupId><artifactId>commons-io</artifactId><version>2.4</version></dependency>
123456/** * 查询一次部署对应的流程定义文件名称和对应的输入流(bpmn png) */@Testpublic void test6_1() throws Exception {String deploymentId = "20001";List<String> names = processEngine.getRepositoryService().getDeploymentResourceNames(deploymentId);for (String name : names) {System.out.println(name);InputStream in = processEngine.getRepositoryService().getResourceAsStream(deploymentId, name);// 将文件保存到本地磁盘File file = new File("d:\\" + name);File f1=new File( file.getParent());if(f1.exists()==false){f1.mkdirs();}FileUtils.copyInputStreamToFile(in, new File("d:\\" + name));in.close();}}
1234567891011121314151617181920219.7 获取PNG文件输入流/** * 获得png文件的输入流 */@Testpublic void test7() throws Exception {String processDefinitionId = "HelloWorldKsy:2:2504";InputStream pngInputStream = processEngine.getRepositoryService().getProcessDiagram(processDefinitionId);FileUtils.copyInputStreamToFile(pngInputStream, new File("d:\\my.png"));}
123456789109.8 启动流程定义2种方式/** * 启动流程实例 方式一:根据流程定义的id启动 方式二:根据流程定义的key启动(自动选择最新版本的流程定义启动流程实例) */@Testpublic void test8() {/* * String processDefinitionId = "HelloWorldKsy:2:2504"; ProcessInstance * processInstance = * processEngine.getRuntimeService().startProcessInstanceById * (processDefinitionId ); System.out.println(processInstance.getId()); */
String processDefinitionKey = "HelloWorldKsy";ProcessInstance processInstance = processEngine.getRuntimeService().startProcessInstanceByKey(processDefinitionKey);System.out.println(processInstance.getId());}
123456789101112131415161718根据Key启动流程,会使用最新的的流程定义的Key。选择最新的流程定义进行启动!
9.9 查询流程实例列表/** * 查询流程实例列表,查询act_ru_execution表 */@Testpublic void test9(){//流程实例查询对象,查询act_ru_execution表ProcessInstanceQuery query = processEngine.getRuntimeService().createProcessInstanceQuery();query.processDefinitionKey("HelloWorldKsy");query.orderByProcessInstanceId().desc();query.listPage(0, 2);List<ProcessInstance> list = query.list();for (ProcessInstance pi : list) {System.out.println(pi.getId() + " " + pi.getActivityId());}}
123456789101112131415169.10 结束流程实例/** * 结束流程实例,操作的表act_ru_execution act_ru_task */@Testpublic void test10(){String processInstanceId = "10001";processEngine.getRuntimeService().deleteProcessInstance(processInstanceId , "我愿意");}
1234567899.11 查询任务列表/** * 查询任务列表 */@Testpublic void test11() {// 任务查询对象,查询act_ru_task表TaskQuery query = processEngine.getTaskService().createTaskQuery();String assignee = "张三";query.taskAssignee(assignee);query.orderByTaskCreateTime().desc();List<Task> list = query.list();for (Task task : list) {System.out.println(task.getId());}}
123456789101112131415169.12 查询任务列表/** * 办理任务 */@Testpublic void test12(){String taskId = "32504";processEngine.getTaskService().complete(taskId);}
1234567899.13 查询最新版本的流程定义列表/** * 查询最新版本的流程定义列表 */@Testpublic void test14() {ProcessDefinitionQuery query = processEngine.getRepositoryService().createProcessDefinitionQuery();query.orderByProcessDefinitionVersion().asc();List<ProcessDefinition> list = query.list();Map<String, ProcessDefinition> map = new HashMap<String, ProcessDefinition>();for (ProcessDefinition pd : list) {map.put(pd.getKey(), pd);}ArrayList<ProcessDefinition> lastList = new ArrayList<>(map.values());for (ProcessDefinition processDefinition : lastList) {System.out.println(processDefinition.getName() + "  " + processDefinition.getVersion());}}
————————————————版权声明:本文为CSDN博主「会写一点java的Dragon」的原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接及本声明。原文链接:https://blog.csdn.net/qq_43207259/article/details/84311227

原文地址:https://www.cnblogs.com/yhxb/p/11679997.html

时间: 2024-10-04 16:57:10

Activiti(基础)的相关文章

Activiti基础教程--01(简介、代码生成Activiti的25张表、Activiti配置文件activiti.cfg.xml生成25张表、在Eclipse上安装Activiti插件)

一.简介 Activiti项目是一项新的基于Apache许可的开源BPM平台,从基础开始构建,旨在提供支持新的BPMN 2.0标准,包括支持对象管理组(OMG),面对新技术的机遇,诸如互操作性和云架构,提供技术实现. 创始人Tom Baeyens是JBoss jBPM的项目架构师,以及另一位架构师Joram Barrez,一起加入到创建Alfresco这项首次实现Apache开源许可的BPMN 2.0引擎开发中来. Activiti是一个独立运作和经营的开源项目品牌,并将独立于Alfresco开

Activiti动态设置办理人扩展

作者:邓家海 扩展是要求对Activiti基础有一定的功底的 我们一直在努力,不是为了改变世界,只是不让世界去改变我们. 关键词:Assignee.Candidate users.Candidate groups:setAssignee.taskCandidateUser.taskCandidateGroup 主要解决问题:Activiti动态给任务节点设置办理人. 情景: 我们在做工作流开发,学习的时候一般都有这么一个过程: 第一阶段:最开始学习的时候,喜欢在设计流程的时候写死人名(即)办理人

java web 开发三剑客 -------电子书

Internet,人们通常称为因特网,是当今世界上覆盖面最大和应用最广泛的网络.根据英语构词法,Internet是Inter + net,Inter-作为前缀在英语中表示“在一起,交互”,由此可知Internet的目的是让各个net交互.所以,Internet实质上是将世界上各个国家.各个网络运营商的多个网络相互连接构成的一个全球范围内的统一网,使各个网络之间能够相互到达.各个国家和运营商构建网络采用的底层技术和实现可能各不相同,但只要采用统一的上层协议(TCP/IP)就可以通过Internet

activiti入门2流程引擎的API和服务基础

RepositoryService : 管理和控制发布包和流程定义(包含了一个流程每个环节的结构和行为)的操作 除此之外,服务可以 查询引擎中的发布包和流程定义. 暂停或激活发布包,对应全部和特定流程定义. 暂停意味着它们不能再执行任何操作了,激活是对应的反向操作. 获得多种资源,像是包含在发布包里的文件, 或引擎自动生成的流程图. 获得流程定义的pojo版本, 可以用来通过java解析流程,而不必通过xml. RuntimeService :负责启动一个流程定义的新实例,获取和保存流程变量,查

activiti的基础环境搭建创建数据库表及策略

博主使用为activiti5.22的版本. 1.创建maven工程. 2.在pom文件中引入所需要的包,如:activiti包.数据库包. 这是我引用的包: <dependencies> <dependency> <groupId>org.activiti</groupId> <artifactId>activiti-spring</artifactId> <version>5.22.0</version> &

Activiti实战04_简单流程

在Activiti实战03_Hello World中我们介绍了一个中间没有任何任务的流程,实现了流程的部署与查阅,而在本章中,将会为流程添加任务节点,是流程能够像个流程,变得更加丰满起来. 在上一节的基础上,我门将会为流程添加实际业务使其能够正常工作起来,先模拟一个很简单的请假流程. 首先,在上一节的流程图中为流程添加一个用户任务(userTask)来处理申请,根据申请内容来决定运行申请还是驳回申请.流程图如下: 代码清单,由于篇幅的原因,这里就不在列出任务的坐标位置等信息 <?xml vers

activiti搭建(五)BPMN介绍

对于BPMN我也不是十分清楚,目前也只是因为对于Modeler中不熟悉的组件查询,来对这部分的内容进行学习,不求一次理解,边学边理解吧.所以这一章的介绍会比较简单,但也足够了. Modeler中的组件列表划分和BPMN的略微有些不同,而且有些内容好像也没有,最后移植到自己的demo中,还遇到了一些问题,如果可能的话,之后会详细介绍一下Modeler的构成,大致是官方文档的第七节Overview以及第十节Process(重要),网上已有人将其归纳总结过了 http://wenku.baidu.co

activiti自定义流程之整合(二):使用angular js整合ueditor创建表单

注:整体环境搭建:activiti自定义流程之整合(一):整体环境配置 基础环境搭建完毕,接下来就该正式着手代码编写了,在说代码之前,我觉得有必要先说明一下activit自定义流程的操作. 抛开自定义的表单不谈,通过之前的了解,我们知道一个新的流程开始,是在启动流程实例(processIntence)的时候,而流程实例依赖于流程定义(processDefinition),流程定义又依赖于流程模型(model). 我们用到的自定义表单需要在创建模型,画模型图的时候就指定表单的名称formKey,需

activiti自己定义流程之Spring整合activiti-modeler实例(一):环境搭建

项目中须要整合activiti-modeler自己定义流程,找了非常多资料后,最终成功的跳转到activiti-modeler流程设计界面.下面是记录: 一.整合基础:eclipse4.4.1.tomcat7.jdk1.7.mysql5.6.25.maven3.2.5.activiti5.16.3.spring4.0.9 二.步骤: 1.下载activiti-5.16.3.zip: http://www.activiti.org/download.html 2.解压zip文件,解压后的文件夹打开