Activiti系列(一)——最简单的Activiti程序

本文介绍Activiti工作流引擎的基本使用方法,包括部署流程定义、启动流程实例、查询及完成个人任务等步骤,并通过示例代码展示如何实现业务流程与系统流程的解耦。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

这篇文章是我在学习Activiti的时候发现的一篇很适合新人的博客

原地址为 http://blog.youkuaiyun.com/qiumuxia0921/article/details/50988487

引言


Activiti工作引擎,用我的话说:简单的就是将业务流程和系统流程分离的框架。


有人问了,我们其实用数据库的几张表,就可以实现,提交我们的信息给指定的下一个人。为什么我们还要用Activiti呢?这个问题,其实很简单,Activiti将我们的业务流程和系统流程分离,简单来讲,就是我们只需要提交我们的信息就行了,不需要知道审批人是谁。这样解耦和。


不多说了,上代码:


先看我们的文件目录:


一、引用jar包:


其中比较重要的包:


二、画bpmn文件:


三、填写各个节点的参数:


我们在提交申请的Properties--Main config 中的Assignee中写入“张三”,例如:



同样的方式,我们在“审批【部门经理】”节点中Properties--Main Config--Assiginee中写入“李四”。


同样的方式,我们在“审批【总经理】”节点中Properties--Main Config--Assiginee中写入“王五”。


四、设置Process的ID:


写好了之后,我们点击空白bpmn文件空白的地方,


五、写xml和类


写activiti.cfg.xml文件:

<span style="font-size:18px;"><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.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">  
  
    <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://localhost:3306/itcast0711activiti?useUnicode=true&characterEncoding=utf8"></property>  
        <property name="jdbcUsername" value="root"></property>  
        <property name="jdbcPassword" value="root"></property>  
        <!-- 没有表创建表 -->  
        <property name="databaseSchemaUpdate" value="true"></property>  
    </bean>  
  
</beans></span>  

添加log4j.properties文件:

<span style="font-size:18px;">log4j.rootLogger=INFO, CA  
  
# ConsoleAppender  
log4j.appender.CA=org.apache.log4j.ConsoleAppender  
log4j.appender.CA.layout=org.apache.log4j.PatternLayout  
log4j.appender.CA.layout.ConversionPattern= %d{hh:mm:ss,SSS} [%t] %-5p %c %x - %m%n</span>  
写HelloWorld类:
import java.util.List;  
  
import org.activiti.engine.ProcessEngine;  
import org.activiti.engine.ProcessEngines;  
import org.activiti.engine.repository.Deployment;  
import org.activiti.engine.runtime.ProcessInstance;  
import org.activiti.engine.task.Task;  
import org.junit.Test;  
  
public class HelloWorld {  
      
    ProcessEngine processEngine = ProcessEngines.getDefaultProcessEngine();  
  
    /**部署流程定义*/  
    @Test  
    public void deploymentProcessDefinition(){  
        Deployment deployment = processEngine.getRepositoryService()//与流程定义和部署对象相关的Service  
                        .createDeployment()//创建一个部署对象  
                        .name("helloworld入门程序")//添加部署的名称  
                        .addClasspathResource("diagrams/helloworld.bpmn")//从classpath的资源中加载,一次只能加载一个文件  
                        .addClasspathResource("diagrams/helloworld.png")//从classpath的资源中加载,一次只能加载一个文件  
                        .deploy();//完成部署  
        System.out.println("部署ID:"+deployment.getId());//1  
        System.out.println("部署名称:"+deployment.getName());//helloworld入门程序    
    }  
      
    /**启动流程实例*/  
    @Test  
    public void startProcessInstance(){  
        //流程定义的key  
        String processDefinitionKey = "helloworld";  
        ProcessInstance pi = processEngine.getRuntimeService()//与正在执行的流程实例和执行对象相关的Service  
                        .startProcessInstanceByKey(processDefinitionKey);//使用流程定义的key启动流程实例,key对应helloworld.bpmn文件中id的属性值,使用key值启动,默认是按照最新版本的流程定义启动  
        System.out.println("流程实例ID:"+pi.getId());//流程实例ID    101  
        System.out.println("流程定义ID:"+pi.getProcessDefinitionId());//流程定义ID   helloworld:1:4  
    }  
      
      
    /**查询当前人的个人任务*/  
    @Test  
    public void findMyPersonalTask(){  
        String assignee = "王五";  
        List<Task> list = processEngine.getTaskService()//与正在执行的任务管理相关的Service  
                        .createTaskQuery()//创建任务查询对象  
                        .taskAssignee(assignee)//指定个人任务查询,指定办理人  
                        .list();  
        if(list!=null && list.size()>0){  
            for(Task task:list){  
                System.out.println("任务ID:"+task.getId());  
                System.out.println("任务名称:"+task.getName());  
                System.out.println("任务的创建时间:"+task.getCreateTime());  
                System.out.println("任务的办理人:"+task.getAssignee());  
                System.out.println("流程实例ID:"+task.getProcessInstanceId());  
                System.out.println("执行对象ID:"+task.getExecutionId());  
                System.out.println("流程定义ID:"+task.getProcessDefinitionId());  
                System.out.println("########################################################");  
            }  
        }  
    }  
      
    /**完成我的任务*/  
    @Test  
    public void completeMyPersonalTask(){  
        //任务ID  
        String taskId = "302";  
        processEngine.getTaskService()//与正在执行的任务管理相关的Service  
                    .complete(taskId);  
        System.out.println("完成任务:任务ID:"+taskId);  
    }  
      
}  

注:


第一个方法deploymentProcessDefinition方法是用来部署流程的,部署流程的意思是说,我们新写了一个工作流的实例,运行deploymentProcessDefinition方法,该工作流实例,就会部署。部署只需要一次就可以了。


第二个方法startProcessInstance()是启动流程实例的方法,这里的processDefinitionKey一定是我们先前的Properties——process——id必须保持一致,因为这个ProcessDefinitionkey就是根据这个值来查找实例那个部署的流程的。


第三个方法findMyPersonalTask()查找个人任务,这里需要的Assignee是我们在画图的时候,在Properties——Main Config——Assignee中的名称保持一致,这里查看“王五”的个人任务,也就是说,当张三提交申请时候,Assignee为“李四”的时候,就会出现李四的任务,李四完成任务,就提交给王五,这个时候,王五就会出现有任务。


第四个方法completeMyPersonalTask()完成任务,这个参数为taskID,也就是说,第三个方法中现查询了是否有任务,当存在任务的时候,我们就将任务的ID为参数,运行这个方法任务就会完成。



评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值