环境准备
在activiti官网.下载activiti环境所需的jar包,在activiti-5.xx->wars目录下是一些示例项目,解压activiti-rest项目,导入activiti-rest目录中WEB-INF\lib下所有包。添加到classpath中。
由于我们使用的是Mysql数据库,Mysql数据库的链接驱动Activiti官方包中并没有提供,需要我们自己导入。手动导入mysql-connector-java.jar,添加到classpath下。
目录结构如图
方式1
初始化数据库
@Test
public void test() {
//创建工作流配置实例
ProcessEngineConfiguration configuration = ProcessEngineConfiguration.createStandaloneInMemProcessEngineConfiguration();
//设置jdbc连接信息
configuration.setJdbcUrl("jdbc:mysql://localhost:3306/activiti_db");
configuration.setJdbcUsername("root");
configuration.setJdbcPassword("1123");
configuration.setJdbcDriver("com.mysql.jdbc.Driver");
//设置数据库建表策略
/* DB_SCHEMA_UPDATE_FALSE 如果不存在表就抛出异常;
DB_SCHEMA_UPDATE_CREATE_DROP 每次都先删除 ,建立新的表;
DB_SCHEMA_UPDATE_TRUE 如果不存在就建表,存在就直接使用;*/
configuration.setDatabaseSchemaUpdate(ProcessEngineConfiguration.DB_SCHEMA_UPDATE_TRUE);
//使用配置对象创建工作流引擎实例
ProcessEngine processEngine = configuration.buildProcessEngine();
System.out.println(processEngine);
}
在Activiti中,在创建核心的流程引擎对象时会自动建表。如果程序正常执行,mysql会自动建库,然后创建23张表。
控制打印信息
数据库中的表信息
方式2:添加并制定配置文件方式
在Activiti5的官方示例中先得找到activiti-rest\WEB-INF\classes下有:activiti-custom-context.xml
参照此文件在classpath下创建activiti.cfg.xml文件如下:
<?xml version="1.0" encoding="UTF-8"?><bean id="dbProperties" class="org.springframework.beans.factory.config.PropertyPlaceholderConfigurer">
<property name="ignoreUnresolvablePlaceholders" value="true" />
<property name="ignoreResourceNotFound" value="true" />
</bean>
<bean id="dataSource"
class="org.springframework.jdbc.datasource.SimpleDriverDataSource">
<property name="driverClass" value="com.mysql.jdbc.Driver" />
<property name="url" value="jdbc:mysql://localhost:3306/activiti_db" />
<property name="username" value="root" />
<property name="password" value="1123" />
</bean>
<bean id="transactionManager"
class="org.springframework.jdbc.datasource.DataSourceTransactionManager">
<property name="dataSource" ref="dataSource" />
</bean>
<bean id="processEngineConfiguration" class="org.activiti.spring.SpringProcessEngineConfiguration">
<property name="dataSource" ref="dataSource" />
<property name="transactionManager" ref="transactionManager" />
<property name="databaseSchemaUpdate" value="true" />
<property name="mailServerHost" value="localhost" />
<property name="mailServerPort" value="5025" />
<property name="jobExecutorActivate" value="false" />
<property name="customFormTypes">
<list>
<bean class="org.activiti.rest.form.UserFormType"/>
<bean class="org.activiti.rest.form.ProcessDefinitionFormType"/>
<bean class="org.activiti.rest.form.MonthFormType"/>
</list>
</property>
</bean>
<bean id="processEngine" class="org.activiti.spring.ProcessEngineFactoryBean">
<property name="processEngineConfiguration" ref="processEngineConfiguration" />
</bean>
<bean id="repositoryService" factory-bean="processEngine" factory-method="getRepositoryService" />
<bean id="runtimeService" factory-bean="processEngine" factory-method="getRuntimeService" />
<bean id="taskService" factory-bean="processEngine" factory-method="getTaskService" />
<bean id="formService" factory-bean="processEngine" factory-method="getFormService" />
<bean id="historyService" factory-bean="processEngine" factory-method="getHistoryService" />
<bean id="managementService" factory-bean="processEngine" factory-method="getManagementService" />
<bean id="identityService" factory-bean="processEngine" factory-method="getIdentityService" />
Java代码如下:
@Test
public void test1() {
//创建工作流实例
ProcessEngine processEngine = ProcessEngineConfiguration.createProcessEngineConfigurationFromResource("activiti.cfg.xml")
.buildProcessEngine();
System.out.println(processEngine);
}
createProcessEngineConfigurationFromResource的参数值为我们添加的配置文件activiti.cfg.xml的名称,执行java代码,流程引擎对象创建成功运行后数据库会自动建表。
方式3:
在前面看到了两种创建ProcessEngine(流程引擎)的方式,而这里要简化很多,调用ProcessEngines的getDefaultProceeEngine方法时会自动加载classpath下名为activiti.cfg.xml文件。
Java代码如下:
@Test
public void test2() {
//创建工作流实例
ProcessEngine processEngine = ProcessEngines.getDefaultProcessEngine();
System.out.println(processEngine);
}