activiti学习-02环境准备+安装流程设计器+对流程设计器的使用+对流程设计器的使用+核心API的认识

来源:互联网 发布:seo内部优化包括 编辑:程序博客网 时间:2024/06/04 01:18

1环境
JDK1.6或者更高版本(我的配置是1.7)
支持的数据库有:h2, mysql, oracle, postgres, mssql, db2等。(我的配置是mysql5.7.19)
支持activiti5运行的jar包
开发环境为Eclipse3.7或者以上版本,myeclipse为8.6版本(我的配置是Mars.1 Release (4.5.1))

2安装流程设计器(eclipse插件)
http://blog.csdn.net/zhou920786312/article/details/77847972

3对流程设计器的使用
这里写图片描述
保存diagram时候自动生成图片

4初始化数据库
方式1

@Testpublic void createTable(){        ProcessEngineConfiguration processEngineConfiguration = ProcessEngineConfiguration.createStandaloneProcessEngineConfiguration();        //连接数据库的配置        processEngineConfiguration.setJdbcDriver("com.mysql.jdbc.Driver");        processEngineConfiguration.setJdbcUrl("jdbc:mysql://110.110.1.211:3306/test2?useUnicode=true&characterEncoding=utf8");        processEngineConfiguration.setJdbcUsername("root");        processEngineConfiguration.setJdbcPassword("root");        /**            public static final String DB_SCHEMA_UPDATE_FALSE = "false";不能自动创建表,需要表存在            public static final String DB_SCHEMA_UPDATE_CREATE_DROP = "create-drop";先删除表再创建表            public static final String DB_SCHEMA_UPDATE_TRUE = "true";如果表不存在,自动创建表         */        processEngineConfiguration.setDatabaseSchemaUpdate(ProcessEngineConfiguration.DB_SCHEMA_UPDATE_TRUE);        //工作流的核心对象,ProcessEnginee对象        ProcessEngine processEngine = processEngineConfiguration.buildProcessEngine();        System.out.println("processEngine:"+processEngine);    }输出:02:07:39,826 [main] INFO  org.activiti.engine.impl.db.DbSqlSession  - performing create on engine with resource org/activiti/db/create/activiti.mysql.create.engine.sql02:07:40,658 [main] INFO  org.activiti.engine.impl.db.DbSqlSession  - performing create on history with resource org/activiti/db/create/activiti.mysql.create.history.sql02:07:40,879 [main] INFO  org.activiti.engine.impl.db.DbSqlSession  - performing create on identity with resource org/activiti/db/create/activiti.mysql.create.identity.sql02:07:40,940 [main] INFO  org.activiti.engine.impl.ProcessEngineImpl  - ProcessEngine default createdprocessEngine:org.activiti.engine.impl.ProcessEngineImpl@1f90eeec

数据库自动生成的表
这里写图片描述

方式2

这里写图片描述

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"><!--  public static ProcessEngineConfiguration createStandaloneProcessEngineConfiguration() {    return new StandaloneProcessEngineConfiguration();}     这段对应下面的bean:processEngineConfiguration  -->    <bean id="processEngineConfiguration" class="org.activiti.engine.impl.cfg.StandaloneProcessEngineConfiguration">        <!-- 连接数据的配置 -->        <property name="jdbcDriver" value="com.mysql.jdbc.Driver"></property>        <property name="jdbcUrl" value="jdbc:mysql://110.110.1.211:3306/test3?useUnicode=true&amp;characterEncoding=utf8"></property>        <property name="jdbcUsername" value="root"></property>        <property name="jdbcPassword" value="root"></property>        <!-- 没有表创建表 -->        <!--processEngineConfiguration.setDatabaseSchemaUpdate(ProcessEngineConfiguration.DB_SCHEMA_UPDATE_TRUE);          这段代码对应的配置如下        -->        <property name="databaseSchemaUpdate" value="true"></property>    </bean></beans>
@Testpublic void createTable_2(){        ProcessEngine processEngine = ProcessEngineConfiguration.createProcessEngineConfigurationFromResource("activiti.cfg.xml")   //                                    .buildProcessEngine();        System.out.println("processEngine2:"+processEngine);    }输出:02:31:09,723 [main] INFO  org.springframework.beans.factory.xml.XmlBeanDefinitionReader  - Loading XML bean definitions from class path resource [activiti.cfg.xml]02:31:11,189 [main] INFO  org.activiti.engine.impl.db.DbSqlSession  - performing create on engine with resource org/activiti/db/create/activiti.mysql.create.engine.sql02:31:11,712 [main] INFO  org.activiti.engine.impl.db.DbSqlSession  - performing create on history with resource org/activiti/db/create/activiti.mysql.create.history.sql02:31:11,851 [main] INFO  org.activiti.engine.impl.db.DbSqlSession  - performing create on identity with resource org/activiti/db/create/activiti.mysql.create.identity.sql02:31:11,945 [main] INFO  org.activiti.engine.impl.ProcessEngineImpl  - ProcessEngine default createdprocessEngine2:org.activiti.engine.impl.ProcessEngineImpl@5e0d095e

自动生成的表
这里写图片描述

核心API的认识

ProcessEngine 总路口
RepositoryService 管理流程定义
RuntimeService 执行管理,包括启动、推进、删除流程实例等操作
TaskService 任务管理
HistoryService 历史管理(执行完的数据的管理)
IdentityService 组织机构管理
FormService 一个可选服务,任务表单管理
ManagerService
ProcessDefinition 流程定义类。可以从这里获得资源文件等。
ProcessInstance:
代表流程定义的执行实例。如小黄请了一天的假,就必须发出一个流程实例的申请。一个流程实例包括了所有的运行节点。我们可以利用这个对象来了解当前流程实例的进度等信息。流程实例就表示一个流程从开始到结束的最大的流程分支,即一个流程中流程实例只有一个。
Execution:
Activiti用这个对象去描述流程执行的每一个节点。在没有并发的情况下,Execution等同ProcessInstance。流程按照流程定义的规则执行一次的过程,就可以表示执行对象Execution。
一个流程中,执行对象可以存在多个,但是流程实例只能有一个。
当流程按照规则只执行一次的时候,那么流程实例就是执行对象。

源码分析:

public interface ProcessInstance extends Execution {

在单线流程中,如上图的贷款流程,ProcessInstance与Execution是一致的,如下图所示
这里写图片描述
多流程中,如wire money(汇钱)和archive(存档)是并发执行的。 这个时候,总线路代表ProcessInstance,而分线路中每个活动代表Execution。
这里写图片描述

阅读全文
0 0
原创粉丝点击