工作流Activiti的学习总结(四)Spring和Activiti的整合配置讲解

工作流Activiti的学习总结(四)Spring和Activiti的整合配置讲解

Spring和Activiti的整合:

在Spring和Activiti的整合中ProcessEngineFactoryBean成为了两者的整合点。ProcessEngineFactoryBean为org.activiti.spring.ProcessEngineFactoryBean。提供了ProcessEngine的配置和创建的功能。

<bean

id="processEngineConfiguration"class="org.activiti.spring.SpringProcessEngineConfiguration">

...

</bean>

<bean id="processEngine"class="org.activiti.spring.ProcessEngineFactoryBean"> <property

name="processEngineConfiguration"ref="processEngineConfiguration"/> </bean>

如果在包含事物的activiti配置如下:

<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/20xx/XMLSchema-instance"

xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd

http://www.springframework.org/schema/context

http://www.springframework.org/schema/context/spring-context-2.5.xsd http://www.springframework.org/schema/tx

http://www.springframework.org/schema/tx/spring-tx-3.0.xsd">

<!-- 采用spring的数据源类创建一个数据源 -->

<bean

id="dataSource"class="org.springframework.jdbc.datasource.SimpleDriverDataSource">

<property name="driverClass"value="org.h2.Driver"/>

<property name="url"value="jdbc:h2:mem:activiti;DB_CLOSE_DELAY=1000"/> <property name="username"value="sa"/>

<property name="password"value=""/>

</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"/>

<!-- 设置数据库schema的更新方式 -->

<property name="databaseSchemaUpdate"value="true"/>

<!-- 是否启动jobExecutor -->

<property name="jobExecutorActivate"value="false"/>

</bean>

<!-- 创建一个流程引擎bean -->

<bean id="processEngine"class="org.activiti.spring.ProcessEngineFactoryBean"> <property

name="processEngineConfiguration"ref="processEngineConfiguration"/> </bean>

<!-- 创建activiti提供的各种服务 -->

<!-- 工作流仓储服务 -->

<bean

id="repositoryService"factory-bean="processEngine"factory-method="getRepositoryService"/>

<!-- 工作流运行服务 -->

id="runtimeService"factory-bean="processEngine"factory-method="getRuntimeService"/>

<!-- 工作流任务服务-->

<bean

id="taskService"factory-bean="processEngine"factory-method="getTaskService"/>

<!-- 工作流历史数据服务-->

<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"/>

...

工作流中Expressions的使用

在使用spring的SpringProcessEngineConfiguration时,如果没有beans属性表示所有bean都可以暴露给activiti的流程文件xml访问。如果配置beans但是没有配置map中bean信息,则没有暴露的bean。如果map中配置部分bean表示只是暴露部分bean给activiti使用。

<bean

id="processEngineConfiguration"class="org.activiti.spring.SpringProcessEngineConfiguration">

...

<property name="beans">

<map>

<entry key="printer"value-ref="printer"/>

</property>

</bean>

<bean id="printer"class="org.activiti.examples.spring.Printer"/>

暴露的bean可以在activiti的流程xml中使用。如下调用bean的方法

<bean id="printer" class="org.activiti.examples.spring.Printer" />

<definitions id="definitions"...>

<process id="helloProcess">

<startEvent id="start"/>

<sequenceFlow id="flow1"sourceRef="start"targetRef="print"/>

<serviceTask id="print"activiti:expression="#{printer.printMessage()}"/> <sequenceFlow id="flow2"sourceRef="print"targetRef="end"/>

<endEvent id="end"/>

</process>

</definitions>

public class Printer {

public void printMessage() {

System.out.println("hello world");

}

}

自动资源部署(Automatic resource deploy)

<bean

id="processEngineConfiguration"class="org.activiti.spring.SpringProcessEngineConfiguration">

...

<property

name="deploymentResources"value="classpath*:/org/activiti/spring/test/autodeployment/autodeploy.*.bpmn20.xml"/>

</bean>

<bean id="processEngine"class="org.activiti.spring.ProcessEngineFactoryBean"> <property

name="processEngineConfiguration"ref="processEngineConfiguration"/>

</bean>

Spring和activit的整合测试

@RunWith(SpringJUnit4ClassRunner.class)

@ContextConfiguration("classpath:org/activiti/spring/test/junit4/springTypicalUsageTest-context.xml")

public class MyBusinessProcessTest {

@Autowired

private RuntimeService runtimeService;

@Autowired

private TaskService taskService;

@Autowired

@Rule

public ActivitiRule activitiSpringRule;

@Test

@Deployment

public void simpleProcessTest() {

runtimeService.startProcessInstanceByKey("simpleProcess");

Task task = taskService.createTaskQuery().singleResult();

assertEquals("My Task", task.getName());

taskService.complete(task.getId());

assertEquals(0, runtimeService.createProcessInstanceQuery().count()); }

}

当在spring的配置中配置ActivitiRule时候,测试bean将自动被注入: <bean id="activitiRule"class="org.activiti.engine.test.ActivitiRule">

<property name="processEngine"ref="processEngine"/>

< /bean>

 

第二篇:工作流Activiti的学习总结(二)activiti中ProcessEngine的创建和数据库表命名规则

工作流Activiti的学习总结(二)activiti中ProcessEngine的创建和数据库表命名规则

数据库表命名规则:

Activiti工作流引擎的数据库表中的表名称都是以 ACT_.第二部分两个字母表示表的类型。使用模糊匹配的方式说明表的类型匹配activiti的服务API. · ACT_RE_*: RE代表仓储(Repository).这种表前缀以“static”表示流程定义信息或者流程资源信息(如流程的图表和规则等).

· ACT_RU_*: RU标识为运行(Runtime)时表。包含流程实例,用户任务和变量任务等在运行时的数据信息。这些表只存储Activiti在流程实例运行执行的数据,在流程结束的时候从表中去除数据。从而保持运行时候数据的表的快速和小数据量.

· ACT_ID_*:ID标识为唯一(Identity)的。包含一些唯一的信息如用户,用户做等信息。

· ACT_HI_*:HI表示历史数据(History)表,包括过期的流程实例,过期的变量和过期的任务等。

· ACT_GE_*:GE表示公用(General data)的数据库表类型。

ProcessEngine接口中暴露了在BPMN和工作流中中所有操作的服务接口。 用户获取流程实例相关的各种运行时信息.

暴露服务用于操作人工操作的任务例如代办( claiming, completing and assigning tasks).

这个服务用于管理用户和用户组已经用户和用户组关系等的。

暴露引擎飞管理和主要操作。

:服务暴露过期流程实例等信息。

在工作流activiti流程引擎中可以通过activiti.cfg.xml配置。

ProcessEngineConfiguration配置一个流程引擎,在用户应用中创建一个流程引擎的可以通过多种方式:

1.基于默认的配置文件创建一个流程引擎:

ProcessEngine processEngine = ProcessEngineConfiguration

.createProcessEngineConfigurationFromResourceDefault() .buildProcessEngine();

2.在缺少配置文件创建一个流程引擎

ProcessEngine processEngine = ProcessEngineConfiguration

.createStandaloneProcessEngineConfiguration()

.buildProcessEngine();

3.获取一个默认的流程引擎

ProcessEngine processEngine = ProcessEngines.getDefaultProcessEngine()

在工作流activiti的classpath路径中activiti.cfg.xml文件位于

activiti-5.6\setup\files\cfg.activiti\standalone中。

Spring的配置内容如下:

<beans xmlns="http://www.springframework.org/schema/beans"

xmlns:xsi="http://www.w3.org/20xx/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="jdbcUrl"

value="jdbc:h2:mem:activiti;DB_CLOSE_DELAY=1000" />

<property name="jdbcDriver" value="org.h2.Driver" />

<property name="jdbcUsername" value="sa" />

<property name="jdbcPassword" value="" />

<property name="databaseSchemaUpdate" value="true" />

<property name="jobExecutorActivate" value="false" />

<property name="mailServerHost" value="mail.my-corp.com" /> <property name="mailServerPort" value="5025" />

</bean>

</beans>

备注:上面activiti.cfg.xml配置必须spring,但是activiti工作流对spring并不是必须的。

通过编程方式ProcessEngineConfiguration

1.使用配置文件 ProcessEngineConfiguration.createProcessEngineConfigurationFromResourceDefault(); ProcessEngineConfiguration.createProcessEngineConfigurationFromResource(String resource); ProcessEngineConfiguration.createProcessEngineConfigurationFromResource(String resource, String beanName); ProcessEngineConfiguration.createProcessEngineConfigurationFromInputStream(InputStream inputStream); ProcessEngineConfiguration.createProcessEngineConfigurationFromInputStream(InputStream inputStream, String beanName);

2.无配置 文件创建方式

ProcessEngineConfiguration.createStandaloneProcessEngineConfiguration

();

ProcessEngineConfiguration.createStandaloneInMemProcessEngineConfiguration();

ProcessEngine processEngine =

ProcessEngineConfiguration.createStandaloneInMemProcessEngineConfiguration()

.setDatabaseSchemaUpdate(ProcessEngineConfiguration.DB_SCHEMA_UPDATE_FALSE)

.setJdbcUrl("jdbc:h2:mem:my-own-db;DB_CLOSE_DELAY=1000")

.setJobExecutorActivate(true)

.buildProcessEngine();

org.activiti.engine.impl.cfg.StandaloneProcessEngineConfiguration: 在独立方式运行的流程引擎使用。

Activiti需要使用事务对象。默认的情况下,在引擎启动的时候检查数据库将检查activiti的是否有schema和schema的版本是否正确.

org.activiti.engine.impl.cfg.StandaloneInMemProcessEngineConfiguration:

this is a convience class for unit testing purposes. Activiti will take care of the transactions. An H2 in-memory database is used by default. The database will be created and dropped when the engine boots and shuts down. When using this, probably no additional configuration is needed (except when using for example the job executor or mail capabilities). ( 测试环境中使用)

org.activiti.spring.SpringProcessEngineConfiguration:

To be used when the process engine is used in a Spring environment. See the Spring integration section for more information. (Spring环境中使用)

org.activiti.engine.impl.cfg.JtaProcessEngineConfiguration:

([EXPERIMENTAL]) to be used when the engine runs in standalone mode, with JTA transactions.(JPA环境中使用)

相关推荐