本帖最后由 小蜀哥哥 于 2018-1-6 11:25 编辑
Activiti基础入门(1)工作流概念: 工作流(Workflow),就是“业务过程的部分或整体在计算机应用环境下的自动化”,它主要解决的是“使在“多个参与者”之间按照某种“预定义的规则”传递文档、信息或任务的过程自动进行,从而实现某个预期的业务目标,或者促使此目标的实现”。其实也就是,把现实生活中流程抽象为计算机流程。
(2)工作流—核心(工作流引擎-ProcessEngine): Activiti工作的核心。负责生成流程运行时的各种实例及数据、监控和管理流程的运行。 (3)Activiti—流程定义语言(BPMN2.0*) 业务流程建模与标注(Business Process Model and Notation,BPMN) ,描述流程的基本符号,包括这些图元如何组合成一个业务流程图(Business Process Diagram) (4)Activiti—数据库持久化 Activiti的后台是有数据库的支持,所有的表都以ACT_开头。 第二部分是表示表的用途的两个字母标识。 用途也和服务的API对应。 1) ACT_RE_*: 'RE'表示repository。 这个前缀的表包含了流程定义和流程静态资源 (图片,规则,等等)。 2) ACT_RU_*: 'RU'表示runtime。 这些运行时的表,包含流程实例,任务,变量,异步任务,等运行中的数据。 Activiti只在流程实例执行过程中保存这些数据, 在流程结束时就会删除这些记录。 这样运行时表可以一直很小速度很快。 3) ACT_ID_*: 'ID'表示identity。 这些表包含身份信息,比如用户,组等等。 4) ACT_HI_*: 'HI'表示history。 这些表包含历史数据,比如历史流程实例, 变量,任务等等。 5) ACT_GE_*: 通用数据, 用于不同场景下。 资源库流程规则表 1)act_re_deployment 部署信息表 2)act_re_model 流程设计模型信息表 3)act_re_procdef 流程定义数据表 运行时数据库表 1)act_ru_execution 运行时流程执行实例表 2)act_ru_identitylink 运行时流程人员表,主要存储任务节点与参与者的相关信息 3)act_ru_task 运行时任务节点表 4)act_ru_variable 运行时流程变量数据表 历史数据库表 1)act_hi_actinst 历史节点表 2)act_hi_attachment 历史附件表 3)act_hi_comment 历史意见表 4)act_hi_identitylink 历史流程人员表 5)act_hi_detail 历史详情表,提供历史变量的查询 6)act_hi_procinst 历史流程实例表 7)act_hi_taskinst 历史任务实例表 8)act_hi_varinst 历史变量表 组织机构表 1)act_id_group 用户组信息表 JBPM_ID_MEMBERSHIP 2)act_id_info 用户扩展信息表 3)act_id_membership 用户与用户组对应信息表 4)act_id_user 用户信息表 这四张表很常见,基本的组织机构管理,关于用户认证方面建议还是自己开发一套,组件自带的功能太简单,使用中有很多需求难以满足 通用数据表 1)act_ge_bytearray 二进制数据表 2)act_ge_property 属性数据表存储整个流程引擎级别的数据,初始化表结构时,会默认插入三条记录。
这里我以BPMN2.0为例子,先给大家演示在eclipse上安装BPMN的插件
(5)Activiti—插件安装 1. 打开 Help -> Install New Software. 在如下
2. 如下Install界面板中,点击Add按钮: 依次输入 Name: Activiti BPMN 3. 在面板正中列表中把所有展示出来的项目都勾上,点击复选框在Detail部分记得选中 "Contact all updates sites.." , 因为它会检查所有当前安装所需要的插件并可以被Eclipse下载.
4. 重启eclipse,点击新建工程new->Other…打开面板,如果看到下图内容如果看到下图的内容则证明安装完成
5. 另外 虽然流程引擎在单独部署bpmn文件的时候会自动生成图片,但是在实际开发中,自动生成的图片可能会导致BPMN中的坐标会有出入,所以我们不仅仅需要BPMN文件,还需要有图片,但是默认情况下是不不自动生成图片的,所以需要我们进行一些配置,如下:
(6)Activiti—开发环境搭建 1. 创建一个普通的java project在此略过
2. 在此我使用的是mysql数据库,因为activiti官方包中并没有提供mysql数据库的链接驱动所以还需要我们自己导入mysql-connector-java.jar 3. 初始化数据库(三种方式) 在activiti中,创建核心的流程引擎对象的时候会自动创建表,也就是我们刚才介绍到的数据库持久化的那些表,如果程序正常运行的话,会自动建库,并且创建23张表,那么接下来我们来看看如何创建流程引擎 ① 编码方式: ② 配置方式:因为在activiti操作中肯定会涉及到数据库,所以第一种方式的话较为繁琐且属于硬编码,并且会产生很大的代码量,所以我们可以把数据库连接配置写入配置文件。那我们就需要创建一个activiti-cfg.xml(文件名可以自行命名)配置文件
createProcessEngineConfigurationFromResource的参数值为我们添加的配置文件activiti.cfg.xml的名称,执行java代码,流程引擎对象创建成功运行后数据库会自动建表 ③ 开发中常用方式: 其实只要我们的配置文件的名称按照规范来,代码还可以简化很多。直接调用ProcessEngines的getDefaultProceeEngine方法时会自动加载classpath下名为activiti.cfg.xml文件。 好了,到此,大家只要运行以后就会创建核心的流程引擎对象,并且数据库中也会自动创建相应的表格,值得一提的是,第三种创建核心流程引擎对象的方法,其实通过查看源码大家就会发现实际上就是对第二种的简单封装。今天就先给大家介绍到这里,后面还会陆续给大家更新activiti 实际开发相关知识
|