1.概述
为了开发一个工作流的项目,先使用了jbpm5.4,结果经过1个月的学习,感觉jbpm存在以下问题:1.配置复杂,文档较少。2.缺少在实际环境中运行的演示代码;3.代码在演示环境中一次运行完成正常,但是在实际运行环境中不可能一次创建对象后完成,每次恢复时代码就会出现异常,经过长时间的研究,串行流程恢复执行能够正常,但并行流程恢复执行又出现异常。不得以,换成Activiti试一下。
个人感觉JBPM的代码还是比较混乱的,离稳定的运行还有很长的路要走。
具体文献参考官方文献5.13用户指南《http://www.activiti.org/userguide/index.html#activiti.setup》。
到官方网站下载:activiti-5.11.zip
2.环境要求和基本演示
(1)操作系统环境变量中要配置JAVA_HOME
(2)将activiti-5.13.zip压缩文件中的activiti-explorer.war 复制到tomcat中的webapps
(3)启动浏览器http://localhost:8080/activiti-explorer,以 kermit/kermit登录
演示版本中共有三个用户
UserId Password Security roles
kermit kermit admin
gonzo gonzo manager
fozzie fozzie user
(4)下载eclipse_indigo(eclipse3.7),解压缩运行,indigo版本集成了maven,插件Activiti BPMN 2.0 designer必须安装在indigo中
(5)运行eclipse,安装Activiti BPMN 2.0 designer插件,具体参见:http://www.ecmkit.com/zh-hans/2012/03/21/activiti-workflow-hell
Help -> Install New Software,输入以下站点信息:
Name: Activiti BPMN 2.0 designer
Location: http://activiti.org/designer/update/
3.数据库配置为oracle
(1)将database->create目录中对应的sql语句复制到数据库中执行即可
我的是oracle11g,结果出现了“A-01460: 转换请求无法实现或不合理”问题,将驱动转换成ojdbc6.jar,还要在环境变量classpath中配置一下
4.相关jar包
(1)在eclipse中新建一个Web Project
(2)将activiti-5.11中lib目录下所有jar包复制到web-inf\lib\
(3)复制activation-1.1.jar;commons-dbcp-1.4.jar;commons-email-1.2.jar;commons-lang3-3.1.jar;commons-logging.jar;commons-pool-1.5.4.jar;mail-1.4.1.jar
spring 3.1所有jar包,数据库jar包
(4)相关jar包如果没有,可以到这个去下http://yiyiboy2010.iteye.com/blog/1530924
4.演示代码
(1)新建一个bpmn
可以自己新建,也可以用http://yiyiboy2010.iteye.com/blog/1530924里的Interview.bpmn20.xml,将名字改成Interview.bpmn,放在根目录下
注意:从activti5.10开始,bpmn20.xml后缀都改成了bpmn,如果需要图片,自己从eclipse中导出
(2)在根目录下新建一个数据库配置文件activiti.cfg.xml
点击(此处)折叠或打开
<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
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">
<bean id="processEngineConfiguration"
class="org.activiti.engine.impl.cfg.StandaloneProcessEngineConfiguration">
<property name="databaseSchemaUpdate" value="true" />
<property name="jdbcUrl" value="jdbc:mysql://localhost:3306/webauth?useUnicode=true&characterEncoding=utf-8" />
<property name="jdbcDriver" value="com.mysql.jdbc.Driver" />
<property name="jdbcUsername" value="root" />
<property name="jdbcPassword" value="" />
<property name="jobExecutorActivate" value="true" />
</bean>
<!--
<bean id="processEngineConfiguration" class="org.activiti.engine.impl.cfg.StandaloneProcessEngineConfiguration">
<property name="databaseSchemaUpdate" value="true" />
<property name="jdbcUrl" value="jdbc:oracle:thin:@192.108.119.45:1521:test" />
<property name="jdbcDriver" value="oracle.jdbc.driver.OracleDriver" />
<property name="jdbcUsername" value="username" />
<property name="jdbcPassword" value="password" />
<property name="jobExecutorActivate" value="true" />
</bean>
-->
</beans>
(3)新建一个java测试类
点击(此处)折叠或打开
import java.util.List;
import org.activiti.engine.HistoryService;
import org.activiti.engine.ProcessEngine;
import org.activiti.engine.ProcessEngineConfiguration;
import org.activiti.engine.RepositoryService;
import org.activiti.engine.RuntimeService;
import org.activiti.engine.TaskService;
import org.activiti.engine.history.HistoricProcessInstance;
import org.activiti.engine.task.Task;
public class Test {
//本流程模拟的是某公司2012年实习生招聘流程
//张三来参加该招聘流程,公司相关负责人负责处理流程
public static void main(String[] args) {
//加载配置文件
ProcessEngine processEngine = ProcessEngineConfiguration
.createProcessEngineConfigurationFromResource("activiti.cfg.xml")
.buildProcessEngine();
RepositoryService repositoryService = processEngine.getRepositoryService();
RuntimeService runtimeService = processEngine.getRuntimeService();
repositoryService.createDeployment()
.addClasspathResource("Interview.bpmn")
.deploy();
String processId = runtimeService.startProcessInstanceByKey("Interview").getId();
TaskService taskService = processEngine.getTaskService();
HistoryService historyService = processEngine.getHistoryService();
//得到笔试的流程
System.out.println("***************笔试流程开始***************");
List<Task> tasks = taskService.createTaskQuery().taskCandidateGroup("人力资源部").list();
for (Task task : tasks) {
System.out.println("人力资源部的任务:name:"+task.getName()+",id:"+task.getId());
taskService.claim(task.getId(), "张三");
}
System.out.println("张三的任务数量:"+taskService.createTaskQuery().taskAssignee("张三").count());
tasks = taskService.createTaskQuery().taskAssignee("张三").list();
for (Task task : tasks) {
System.out.println("张三的任务:name:"+task.getName()+",id:"+task.getId());
taskService.complete(task.getId());
}
System.out.println("张三的任务数量:"+taskService.createTaskQuery().taskAssignee("张三").count());
System.out.println("***************笔试流程结束***************");
System.out.println("***************一面流程开始***************");
tasks = taskService.createTaskQuery().taskCandidateGroup("技术部").list();
for (Task task : tasks) {
System.out.println("技术部的任务:name:"+task.getName()+",id:"+task.getId());
taskService.claim(task.getId(), "李四");
}
System.out.println("李四的任务数量:"+taskService.createTaskQuery().taskAssignee("李四").count());
for (Task task : tasks) {
System.out.println("李四的任务:name:"+task.getName()+",id:"+task.getId());
taskService.complete(task.getId());
}
System.out.println("李四的任务数量:"+taskService.createTaskQuery().taskAssignee("李四").count());
System.out.println("***************一面流程结束***************");
System.out.println("***************二面流程开始***************");
tasks = taskService.createTaskQuery().taskCandidateGroup("技术部").list();
for (Task task : tasks) {
System.out.println("技术部的任务:name:"+task.getName()+",id:"+task.getId());
taskService.claim(task.getId(), "李四");
}
System.out.println("李四的任务数量:"+taskService.createTaskQuery().taskAssignee("李四").count());
for (Task task : tasks) {
System.out.println("李四的任务:name:"+task.getName()+",id:"+task.getId());
taskService.complete(task.getId());
}
System.out.println("李四的任务数量:"+taskService.createTaskQuery().taskAssignee("李四").count());
System.out.println("***************二面流程结束***************");
System.out.println("***************HR面流程开始***************");
tasks = taskService.createTaskQuery().taskCandidateGroup("人力资源部").list();
for (Task task : tasks) {
System.out.println("技术部的任务:name:"+task.getName()+",id:"+task.getId());
taskService.claim(task.getId(), "李四");
}
System.out.println("李四的任务数量:"+taskService.createTaskQuery().taskAssignee("李四").count());
for (Task task : tasks) {
System.out.println("李四的任务:name:"+task.getName()+",id:"+task.getId());
taskService.complete(task.getId());
}
System.out.println("李四的任务数量:"+taskService.createTaskQuery().taskAssignee("李四").count());
System.out.println("***************HR面流程结束***************");
System.out.println("***************录用流程开始***************");
tasks = taskService.createTaskQuery().taskCandidateGroup("人力资源部").list();
for (Task task : tasks) {
System.out.println("技术部的任务:name:"+task.getName()+",id:"+task.getId());
taskService.claim(task.getId(), "李四");
}
System.out.println("李四的任务数量:"+taskService.createTaskQuery().taskAssignee("李四").count());
for (Task task : tasks) {
System.out.println("李四的任务:name:"+task.getName()+",id:"+task.getId());
taskService.complete(task.getId());
}
System.out.println("李四的任务数量:"+taskService.createTaskQuery().taskAssignee("李四").count());
System.out.println("***************录用流程结束***************");
HistoricProcessInstance historicProcessInstance = historyService
.createHistoricProcessInstanceQuery()
.processInstanceId(processId).singleResult();
System.out.println("流程结束时间:"+historicProcessInstance.getEndTime());
System.exit(0);
}
}
运行结果为
点击(此处)折叠或打开
***************笔试流程开始***************
人力资源部的任务:name:笔试,id:8
张三的任务数量:1
张三的任务:name:笔试,id:8
张三的任务数量:0
***************笔试流程结束***************
***************一面流程开始***************
技术部的任务:name:技术一面,id:11
李四的任务数量:1
李四的任务:name:技术一面,id:11
李四的任务数量:0
***************一面流程结束***************
***************二面流程开始***************
技术部的任务:name:技术二面,id:14
李四的任务数量:1
李四的任务:name:技术二面,id:14
李四的任务数量:0
***************二面流程结束***************
***************HR面流程开始***************
技术部的任务:name:HR面,id:17
李四的任务数量:1
李四的任务:name:HR面,id:17
李四的任务数量:0
***************HR面流程结束***************
***************录用流程开始***************
技术部的任务:name:录用,发放Offer,id:20
李四的任务数量:1
李四的任务:name:录用,发放Offer,id:20
李四的任务数量:0
***************录用流程结束***************
流程结束时间:Wed Jul 31 16:35:45 CST 2013
参考文献
1.activiti学习笔记2. http://yiyiboy2010.iteye.com/blog/1530924
分享到:
相关推荐
"activiti5.13设计器eclipse插件"就是专门为在 Eclipse 中设计 Activiti 流程图而定制的工具。通过这个插件,开发者可以在 Eclipse 中直接创建、编辑和调试 Activiti 流程定义,无需离开熟悉的开发环境。 安装该...
以上提到的内容概述了Activiti 5.13用户指南的主要知识点和操作指南,涵盖了从环境配置、基础入门、API和服务使用、Spring集成、BPMN模型构建、表单处理、历史数据查询、工具使用到REST API集成的全方位知识体系。...
### Activiti 5.13 用户手册核心知识点详解 #### 一、简介 - **协议**: Activiti 5.13 遵循开放源代码许可协议,这意味着开发者可以自由地使用、修改和分发该软件。 - **下载**: 官方网站提供了Activiti 5.13的...
本篇文章将深入探讨Activiti 5.13中的关键知识点及其依赖的jar包。 首先,让我们了解什么是Activiti。Activiti 是基于Java的轻量级工作流引擎,它实现了Business Process Model and Notation (BPMN) 2.0标准。这个...
在开发过程中,`activiti5.13`压缩包包含了一系列必要的JAR文件,这些文件是Activiti运行和功能实现的基础。以下是一些关键知识点: 1. **Activiti Engine JAR**:这是核心引擎库,包含了流程定义、执行、任务管理...
在“activiti-5.13.zip”这个压缩包中,我们能够获取到Activiti 5.13版本的相关资源,包括核心引擎、用户界面以及其他必要的组件。 Activiti 的核心功能主要包括: 1. **流程定义**:使用BPMN 2.0标准,Activiti...
### Activiti 5.13 中文用户手册关键知识点概览 #### 一、环境配置与依赖 **标题概述:** Activiti 5.13 中文用户手册提供了详细的环境配置指南。 **描述详情:** 为了确保Activiti 5.13能够正常运行,手册推荐...
Activiti工作流的使用手册,包括Activiti以及API的介绍
Activiti 5.13 中文用户手册
1. **Activiti安装与配置**:了解如何下载、安装和启动Activiti引擎,以及如何配置数据库连接和其他运行时参数。 2. **模型设计**:学习使用BPMN 2.0语法创建流程模型,如开始事件、结束事件、用户任务、服务任务、...
在安装和使用"activiti-5.13"时,你需要: 1. 安装并配置 JRE,确保环境变量`JAVA_HOME`指向正确的 JRE 安装路径。 2. 安装 Ant,并将其添加到系统路径中,以便执行构建脚本。 3. 下载并解压"activiti-5.13"压缩包,...
Activiti5.13帮助文档.CHM
Activiti 是一个开源的工作流和业务流程管理(BPM)平台,版本5.13提供了丰富的功能和改进。本手册将详细介绍如何使用Activiti进行流程设计、开发和部署。 1. **系统需求与安装** Activiti 5.13 需要JDK 6或更高...
Activiti项目是一项新的基于Apache许可的开源BPM平台,从基础开始构建,旨在提供支持新的BPMN 2.0标准,包括支持对象管理组(OMG),面对新技术的机遇,诸如互操作性和云架构,提供技术实现。 创始人Tom Baeyens是...
在Activiti 5.13版本中,数据库设计是整个框架的核心部分,它确保了流程实例的高效运行和数据存储的稳定性。本说明书将深入解析该框架的数据库设计结构,包括逻辑结构、各个关键表的含义及索引信息。 1、结构设计 ...
Activiti_5.13_ER图 更新。原为5.12
标题"activiti-5.13"指的是Activiti的一个特定版本,即5.13版。在这个版本中,我们可以探讨几个关键的知识点: 1. **Activiti概述**:Activiti是基于Java的轻量级工作流引擎,它支持BPMN 2.0标准,使得业务流程可以...
- **一分钟入门**:快速了解如何安装和配置 Activiti。 - **安装 Activiti**:包括设置环境变量、添加依赖等步骤。 - **安装 Activiti 数据库**:支持多种数据库类型,如 MySQL、PostgreSQL 等。 - **引入 Activiti ...