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&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。
- activiti学习-02环境准备+安装流程设计器+对流程设计器的使用+对流程设计器的使用+核心API的认识
- activiti 网页流程设计器 的使用
- API对设计流程的影响
- 我对流程设计的认识(1)——总论
- 我对流程设计的认识(1)——总论
- Ecipse安装activiti流程设计器插件
- activiti流程设计器汉化
- 工作流Activiti的学习总结(七)Activiti在线流程设计器
- activiti工作流的web流程设计器整合视频教程
- Activiti学习文档(二)之安装流程设计器
- Joshua Bloch访谈:API对设计流程的影响
- Joshua Bloch访谈:API对设计流程的影响
- Joshua Bloch访谈:API对设计流程的影响
- activiti流程设计器activiti designer在eclipse中的安装。
- activiti modeler流程设计器界面定制
- Activiti 流程设计器下载地址
- SpringMvc整合Activiti网页流程设计器
- eclipse中安装Activiti designer流程设计器
- 蓝牙BLE GATT完全分析和运用
- HDU 6186 CS Course(线段树区间操作)
- 机器学习实战 第十一章 代码问题
- Python中的格式化字符
- C++学习之——指针============== 1.
- activiti学习-02环境准备+安装流程设计器+对流程设计器的使用+对流程设计器的使用+核心API的认识
- cout格式化输出整理
- c++学习-匿名名字空间用法
- SegNet
- Python中下划线---完全解读
- java中模拟迭代器实现迭代数组
- Java MD5加密算法的实现
- CCNode类的setPosition,getPosition函数
- css学习笔记