Activiti学习笔记(一)——环境搭建

创建工程

IDEA编译器,新建Maven工程,pom文件中加入以下依赖。其中,注意MySQL的版本要与本地安装的MySQL版本一致。

<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0"
         xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
         xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
    <modelVersion>4.0.0</modelVersion>

    <groupId>com.alex.activiti</groupId>
    <artifactId>my-activiti-demo</artifactId>
    <version>1.0-SNAPSHOT</version>

    <properties>
        <slf4j.version>1.6.6</slf4j.version>
        <log4j.version>1.2.12</log4j.version>
    </properties>

    <dependencies>
        <dependency>
            <groupId>org.activiti</groupId>
            <artifactId>activiti-engine</artifactId>
            <version>7.0.0.Beta1</version>
        </dependency>

        <dependency>
            <groupId>org.activiti</groupId>
            <artifactId>activiti-spring</artifactId>
            <version>7.0.0.Beta1</version>
        </dependency>

        <dependency>
            <groupId>org.activiti</groupId>
            <artifactId>activiti-bpmn-model</artifactId>
            <version>7.0.0.Beta1</version>
        </dependency>

        <dependency>
            <groupId>org.activiti</groupId>
            <artifactId>activiti-bpmn-converter</artifactId>
            <version>7.0.0.Beta1</version>
        </dependency>

        <dependency>
            <groupId>org.activiti</groupId>
            <artifactId>activiti-json-converter</artifactId>
            <version>7.0.0.Beta1</version>
        </dependency>

        <dependency>
            <groupId>org.activiti</groupId>
            <artifactId>activiti-bpmn-layout</artifactId>
            <version>7.0.0.Beta1</version>
        </dependency>

        <dependency>
            <groupId>org.activiti.cloud</groupId>
            <artifactId>activiti-cloud-services-api</artifactId>
            <version>7.0.0.Beta1</version>
        </dependency>

        <dependency>
            <groupId>mysql</groupId>
            <artifactId>mysql-connector-java</artifactId>
            <version>8.0.18</version>
        </dependency>

        <dependency>
            <groupId>junit</groupId>
            <artifactId>junit</artifactId>
            <version>4.12</version>
        </dependency>

        <!-- log start -->
        <dependency>
            <groupId>log4j</groupId>
            <artifactId>log4j</artifactId>
            <version>${log4j.version}</version>
        </dependency>
        <dependency>
            <groupId>org.slf4j</groupId>
            <artifactId>slf4j-api</artifactId>
            <version>${slf4j.version}</version>
        </dependency>
        <dependency>
            <groupId>org.slf4j</groupId>
            <artifactId>slf4j-log4j12</artifactId>
            <version>${slf4j.version}</version>
        </dependency>
        <!-- log end -->

        <dependency>
            <groupId>org.mybatis</groupId>
            <artifactId>mybatis</artifactId>
            <version>3.4.5</version>
        </dependency>

        <dependency>
            <groupId>commons-dbcp</groupId>
            <artifactId>commons-dbcp</artifactId>
            <version>1.4</version>
        </dependency>

    </dependencies>


    <repositories>
        <repository>
            <id>alfresco</id>
            <name>Activiti Releases</name>
            <url>https://artifacts.alfresco.com/nexus/content/repositories/activiti-releases/</url>
            <releases>
                <enabled>true</enabled>
            </releases>
        </repository>
    </repositories>

</project>

本地新建名为activiti的数据库。资源文件中,新建activiti默认的资源配置文件activiti.cfg.xml。其中注意driverClassNameurl(本地使用了MySQL 8.0以上版本),usernamepassword根据实际情况配置。

<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
       xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
       xmlns:context="http://www.springframework.org/schema/context"
       xmlns:tx="http://www.springframework.org/schema/tx"
       xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd
						http://www.springframework.org/schema/contex http://www.springframework.org/schema/context/spring-context.xsd
						http://www.springframework.org/schema/tx http://www.springframework.org/schema/tx/spring-tx.xsd">

    <!--数据源配置-->
    <bean id="dataSource" class="org.apache.commons.dbcp.BasicDataSource">
        <property name="driverClassName" value="com.mysql.cj.jdbc.Driver" />
        <property name="url" value="jdbc:mysql://localhost:3306/activiti?serverTimezone=UTC" />
        <property name="username" value="root" />
        <property name="password" value="aaaaaa" />
        <property name="maxActive" value="3" />
        <property name="maxIdle" value="1" />
    </bean>

    <!--  processEngine配置,使用单独启动方式  -->
    <bean id="processEngineConfiguration" class="org.activiti.engine.impl.cfg.StandaloneProcessEngineConfiguration">
        <!--数据源-->
        <property name="dataSource" ref="dataSource"></property>
        <!--是否生成表结构-->
        <property name="databaseSchemaUpdate" value="true"/>
    </bean>

</beans>

生成数据库表

编写单元测试

@Test
    public void testGenTable() {
        //创建ProcessEngineConfiguration对象
        ProcessEngineConfiguration configuration = ProcessEngineConfiguration.createProcessEngineConfigurationFromResource("activiti.cfg.xml");

        //创建ProcessEngine对象
        ProcessEngine processEngine = configuration.buildProcessEngine();

        //输出
        System.out.println(processEngine);
    }

执行以上程序,控制台输出

org.activiti.engine.impl.ProcessEngineImpl@3e48d38

可以看到activiti数据库中生成了25张表:

act_evt_log
act_ge_bytearray
act_ge_property
act_hi_actinst
act_hi_attachment
act_hi_comment
act_hi_detail
act_hi_identitylink
act_hi_procinst
act_hi_taskinst
act_hi_varinst
act_procdef_info
act_re_deployment
act_re_model
act_re_procdef
act_ru_deadletter_job
act_ru_event_subscr
act_ru_execution
act_ru_identitylink
act_ru_integration
act_ru_job
act_ru_suspended_job
act_ru_task
act_ru_timer_job
act_ru_vatiable

可以看到,根据命名规则,activiti的数据库表可以分为六类:

  • act_evt_* ,事件日志。
  • act_ge_*,ge表示general,通用的,通用数据。
  • act_hi_*,hi表示history,历史的。
  • act_procdef_*,流程定义。
  • act_re_*,re表示repository,包含了相关的资源。
  • act_ru_*,ru表示running,正在运行中的。

更新:2020年8月15日

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: Activiti 是一款流程引擎,它可以通过 Java API 或者 REST API 连接到我们的应用程序中,并提供了丰富的流程管理功能。如果想要获取下一个节点,需要通过 Activiti 的 Java API 进行以下操作: 1. 获得当前任务所在的流程实例,可以使用 ProcessEngine#getRuntimeService() 方法来获取 RuntimeService 对象,并使用该对象下的 createProcessInstanceQuery() 方法查询流程实例。 2. 获得当前任务,可以使用 TaskService# createTaskQuery() 方法查询任务。 3. 通过下一个任务的名称、审批人、代理人等来查询下一个要执行的任务。 4. 获得下一个任务的节点 ID,可以使用查询到的任务对象下的 Task#getExecution() 方法获取当前任务所在的 Execution 对象,再通过 Execution#getActivityId() 方法获取当前任务所在的节点 ID。 5. 获得下一个任务的定义信息,可以使用 ProcessEngine#getRepositoryService() 方法获取 RepositoryService 对象,使用该对象下的 createProcessDefinitionQuery() 方法查询流程定义信息。 通过以上步骤就能够获取下一个节点的 ID 和定义信息。在实际开发中,我们可以将获取下一个节点的操作封装成工具类或者插件,简化我们的代码实现并提高代码可维护性。 ### 回答2: Activiti是一个流程引擎框架,它可以实现工作流管理和业务流程管理。获取下一个节点是Activiti中比较常见的一个任务,可以通过以下几种方式来实现: 1. 使用Java API获取下一个节点:可以通过Activiti提供的Java API来获取流程定义中的下一个节点。使用该API需要连接到Activiti的流程引擎,然后在运行时使用该API调用流程实例以获取下一个节点的信息。 2. 使用表达式获取下一个节点:Activiti支持使用表达式来获取下一个节点,可以通过设置用户任务的连线名称来设置一个表达式。该表达式会在流程运行时被解析,并返回下一个节点的名称。 3. 使用EL表达式获取下一个节点:Activiti还支持使用EL表达式来获取下一个节点。可以在用户任务的连线名称上设置一个表达式,使用EL表达式语言隐藏要执行的目标节点。 4. 使用Activiti内置的下一个节点获取功能:Activiti提供了一些内置功能来获取下一个节点。其中之一是使用默认顺序获取下一个节点。可以在流程模型的流程定义中定义任务顺序,并使用内置函数来获取下一个节点。 总之,Activiti获取下一个节点有多种方式。可以根据自己的实际需求来选择适合的方法。无论使用哪种方法,都需要在谨慎考虑与实践中仔细测试。 ### 回答3: Activiti是一款流程引擎,用于管理和自动化业务流程。在进行业务流程设计时,需要定义各种流程节点,并在流程执行中动态获取下一个节点。本篇文章将介绍如何使用Activiti来获取下一个节点。 1. Activiti中的节点类型 Activiti中有多种节点类型,如开始事件、结束事件、用户任务、服务任务等。其中最常用的节点是用户任务,它代表了需要人来处理的任务。在用户任务的执行过程中,需要获取下一个节点以便继续流程的执行。 2. 获取下一个节点的方法 Activiti提供了多种方式来获取下一个节点,包括: (1)通过代码获取下一个节点 我们可以使用Java代码来获取下一个节点。Activiti中已经封装了相关API,我们只需要按照API的要求来编写代码即可。以下是获取下一个节点的示例代码: //获取当前任务的节点ID String currentTaskID = "xxxxx"; //当前任务对应的节点ID Task currentTask = taskService.createTaskQuery().taskId(currentTaskID).singleResult(); //获取当前任务对应的流程定义ID String processDefinitionID = currentTask.getProcessDefinitionId(); //获取当前任务对应的流程定义 ProcessDefinition processDefinition = repositoryService.createProcessDefinitionQuery().processDefinitionId(processDefinitionID).singleResult(); //获取当前任务后面的所有节点 List<Activity> list = ProcessDiagramGenerator.getAllActivities(processDefinition); //获取下一个节点 Activity nextActivity = list.get(0); (2)使用流程变量获取下一个节点 Activiti中的流程变量可以在任务的执行过程中传递数据。我们可以将下一个节点的ID存储在流程变量中,然后在任务完成后获取这个变量来获取下一个节点。 以下是设置流程变量的示例代码: //设置下一个处理节点的ID String nextNodeId = "xxxxx"; //下一个节点的ID taskService.setVariable(taskId, "nextNodeId", nextNodeId); 获取流程变量的示例代码如下: //获取流程变量中存储的下一个节点的ID String nextNodeId = (String)taskService.getVariable(taskId, "nextNodeId"); 以上是两种常用的获取下一个节点的方法。可以根据具体情况选择合适的方法。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值