【知識總結】Activiti工做流學習入門

 1. 我理解的工做流:html

   在工做中慢慢接觸的業務流程,就向流程控制語言同樣,一步一步都對應的不一樣的業務,但總體串聯起來就是一個完整的業務。並且實際工做中尤爲是在企業內部系統的研發中,確實須要對應許多審批流程的管理。mysql

  而工做流就是可以在程序中,將這些支離破碎的流程,經過配置的方式管理起來,總體做爲一個流程,方便修改,也方便維護。linux

2. 什麼是Activiti:git

  Activiti是一個比較出名的框架,或者說就是一個工做流引擎,通俗的說,就是Activiti引擎咱們只要按照它已有的配置,來進行現有業務的對應,它就可以自動幫助咱們完成之前很差控制的流程問題。程序員

3. 如何獲取Activitigithub

  1. 官網通用打包下載:http://www.activiti.org/ spring

  3. 源代碼github:https://github.com/Activiti/Activitisql

  2. maven自行配置:https://git.oschina.net/flyPiglet/ActivitiStudy/      (個人碼雲、使用git方式能夠取得代碼)數據庫

3. 如何整合到本身的項目中:編程

  1. 編程式整合

    

/** 使用代碼建立工做流須要的23張表 */
    @Test
    public void createTable(){
        // 獲取流程引擎配置(建立一個單例子的流程引擎)
        ProcessEngineConfiguration processEngineConfiguration = ProcessEngineConfiguration
                                                                        .createStandaloneProcessEngineConfiguration();
        // 設置數據庫信息
        processEngineConfiguration.setJdbcDriver("com.mysql.jdbc.Driver"); 
        processEngineConfiguration.setJdbcUrl("jdbc:mysql://localhost:3306/fsop?useUnicode=true&characterEndocing=utf8");
        processEngineConfiguration.setJdbcUsername("root");
        processEngineConfiguration.setJdbcPassword("root");
        /**
         *  processEngineConfiguration 中的配置
         *  DB_SCHEMA_UPDATE_FALSE = "false"; // 不能自動建立表(可以使用腳本建立)
           *    DB_SCHEMA_UPDATE_CREATE_DROP = "create-drop"; // 先刪除再更新
         *  DB_SCHEMA_UPDATE_TRUE = "true"; // 若是表不存在我就自動建立表
         */
        // 設置數據庫操做的設置
        processEngineConfiguration.setDatabaseSchemaUpdate(ProcessEngineConfiguration.DB_SCHEMA_UPDATE_TRUE);
        // 獲取工做流的核心對象
        ProcessEngine processEngine = processEngineConfiguration.buildProcessEngine();
        Assert.assertNotNull(processEngine);
    }

  2. activit引擎使用獨立配置文件

  

/** 使用配置文件建立流程引擎 */
    @Test
    public void createByConfig(){
        ProcessEngine processEngine = ProcessEngineConfiguration
                                                .createProcessEngineConfigurationFromResource("activiti.cfg.xml")
                                                .buildProcessEngine();
        Assert.assertNotNull(processEngine);
    }
<?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"
  xmlns:jee="http://www.springframework.org/schema/jee" xmlns:aop="http://www.springframework.org/schema/aop"
  xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-3.0.xsd
       http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context-3.0.xsd
       http://www.springframework.org/schema/tx http://www.springframework.org/schema/tx/spring-tx-3.0.xsd
       http://www.springframework.org/schema/jee http://www.springframework.org/schema/jee/spring-jee-3.0.xsd
       http://www.springframework.org/schema/aop http://www.springframework.org/schema/aop/spring-aop-3.0.xsd">
       
    <!-- 建立單例子的流程引擎的配置文件 -->
    <bean id="processEngineConfiguration" class="org.activiti.engine.impl.cfg.StandaloneProcessEngineConfiguration">
        <!-- 連接數據庫配置 -->
        <property name="jdbcDriver" value="com.mysql.jdbc.Driver"></property>
        <!-- 轉義的話,須要加入& = &amp; -->
        <property name="jdbcUrl" value="jdbc:mysql://localhost:3306/fsop?useUnicode=true&amp;characterEndocing=utf8"></property>
        <property name="jdbcUsername" value="root"></property>
        <property name="jdbcPassword" value="root"></property>
        <!-- 建立表配置自動建立 -->
        <property name="databaseSchemaUpdate" value="true"></property>
    </bean>
</beans>

  3. 經過Spring配置文件整合

    其實法2就是Spring的整合方式,說白了Activiti就是提供一個入口,操做數據的25張表,較爲規範的完成工做流的實現。

4. 使用流程介紹:

  1. 流程定義:

    1. 在activiti中流程經過什麼方式來管理。

       activiti的流程發佈是經過數據庫加上配置文件的形式來管理的,而配置文件也是具備版本的,activit會將配置文件存儲在數據庫的。

      bpmd的標準規範中,流程是具備代碼表述以及流程圖表述的。因此這兩個的資源都會存儲在數據庫中,以數據庫解析出來的資源爲準。

    2. 定義使用BPMN的規範定義,也就是用XML來管理。

      生成BPMN的方式主要有三種:Activiti Modeler(activit提供的專門裏管理流程文件的war包程序)、Activiti Designer(Eclipse插件,先經過代碼生成後,在進行部署工做)

      Activiti Kickstart(基於表格的流程設計工具)上面兩個都包含其中

    3. Activit提供Activit Explorer以及Activiti REST等寫好的組件來提供方便的後臺調用。

    4. 代碼:其實流程定義有好幾種方式,重點仍是可以使用BPMN標準畫出符合業務需求的流程圖。

  2. 部署流程:

    1. 使用文件部署

    

/**部署流程定義*/
    @Test
    public void deploymentProcessDefinition_classpath(){
        Deployment deployment = processEngine.getRepositoryService() // 與流程定義和部署對象相關的Service
                            .createDeployment() // 建立一個部署對象
                            .name("流程定義") // 設置對應流程的名稱
                            .addClasspathResource("diagrams/helloworld.bpmn") // 從Classpath的資源中加載,一次只能加載一個文件(windows與linux下面要區分)
                            .addClasspathResource("diagrams/helloworld.bpmn") // 從Classpath的資源中加載,圖片
                            .deploy(); // 完成部署

        System.out.println("部署Id:"+deployment.getId()); // 部署Id:20001
        System.out.println("部署名稱:"+deployment.getName()); // 部署名稱:流程定義
    }

    2. 使用流程定義zip文件部署

/**部署流程定義zip文件*/
    @Test
    public void deploymentProcessDefinition_zip(){
        InputStream in = this.getClass().getClassLoader().getResourceAsStream("zip/helloworld.zip");
        ZipInputStream zipInputStream = new ZipInputStream(in);
        Deployment deployment = processEngine.getRepositoryService() // 與流程定義和部署對象相關的Service
                        .createDeployment() // 建立一個部署對象
                        .name("zip流程定義") // 添加部署的名稱
                        .addZipInputStream(zipInputStream) // 制定zip格式文件完成部署
                        .deploy(); // 完成部署
        System.out.println("部署Id:"+deployment.getId()); // 部署Id:22501
        System.out.println("部署名稱:"+deployment.getName()); // 部署名稱:zip流程定義
    }

   3. 使用輸入流部署:

/**部署流程定義zip文件*/
    @Test
    public void deploymentProcessDefinition_inputStream(){
        InputStream inputStreambpmn = this.getClass().getResourceAsStream("/diagrams/processVariables.bpmn");
        InputStream inputStreampng = this.getClass().getResourceAsStream("/diagrams/processVariables.png");
        
        
        Deployment deployment = processEngine.getRepositoryService() // 與流程定義和部署對象相關的Service
                        .createDeployment() // 建立一個部署對象
                        .name("流程定義輸入流") // 添加部署的名稱
                        .addInputStream("processVariables.bpmn", inputStreambpmn)// 使用資源文件名稱(要求與資源文件的名稱要一致),和輸入流完成部署
                        .addInputStream("processVariables.png", inputStreampng)// 使用資源文件名稱(要求與資源文件的名稱要一致),和輸入流完成部署
                        .deploy(); // 完成部署
        System.out.println("部署Id:"+deployment.getId()); // 部署Id:55001
        System.out.println("部署名稱:"+deployment.getName()); // 部署名稱:流程定義輸入流
    }

  3. 啓動流程實例:

    1. 什麼是流程實例:就是一個活生生的流程、流程定義是定義了這一類的流程是如何的,而流程實例就是真正的業務流程。一切操做的基礎都基於流程實例

    2. 啓動流程實例:

/** 啓動流程實例 */
    @Test
    public void startProcessInstance(){
        String processDefinitionKey = "psocessVariables"; // 使用Key的啓動,默認按照對心版本的流程定義啓動
        ProcessInstance pi = processEngine.getRuntimeService() // 與正在執行的流程實例和執行對象相關的Service
                        .startProcessInstanceByKey(processDefinitionKey); // 使用流程定義的Key啓動流程實例,key對應helloworld.bpmn文件中的流程名稱
        
        System.out.println("流程實例Id"+pi.getId()); // 流程實例Id:57501
        System.out.println("流程定義Id"+pi.getProcessDefinitionId()); // 流程定義Id:psocessVariables:1:55004
    }

  4. 流程變量:

    1. 流程變量就是對應一個流程下來全局或者局部的變量,能夠每一個節點都不同,也能夠設置爲全局的,這些都經過數據庫進行傳遞

  5. 任務相關:

    1. 任務,流程裏面對應不少個任務,經過你畫出來的流程圖來自動生成任務。 

  6. 總體圖:

    

    相關API描述:

    

ProcessEngine processEngine = ProcessEngines.getDefaultProcessEngine();

RuntimeService runtimeService = processEngine.getRuntimeService();
RepositoryService repositoryService = processEngine.getRepositoryService();
TaskService taskService = processEngine.getTaskService();
ManagementService managementService = processEngine.getManagementService();
IdentityService identityService = processEngine.getIdentityService();
HistoryService historyService = processEngine.getHistoryService();
FormService formService = processEngine.getFormService();

上述全部的都是經過processEngine,因此其實真正想把它用到項目上也是很容易的,只要配置好數據源、數據庫表創建好、工做流引擎交由Spring管理,不會影響原先的功能只須要在對應的地方調用API便可。

5. 數據庫表說明:

  其實總共就是23張表、因此使用單元測試進行練習,瞭解流程原理,入門仍是挺容易的。

#部署對象和流程定義相關表
#當key值相同的時候版本升級,id未key+版本+隨機生成的值
SELECT * FROM `act_re_deployment`; #部署對象表

SELECT * FROM `act_re_procdef`; #流程定義表`fsop`

SELECT * FROM `act_ge_bytearray`; #資源文件表(一個存儲xml,一個存儲圖片)

SELECT * FROM `act_ge_property`; #逐漸生成策略表(與Id相關)

#####################################################
#流程實例,執行對象,任務
SELECT * FROM `act_ru_execution`; #正在執行的執行對象表(正在執行的流程實例)

SELECT * FROM `act_hi_procinst` WHERE `END_TIME_` IS NULL; #流程實例的歷史表(一個流程實例)

SELECT * FROM `act_ru_task`; #正在執行的任務表(只有節點是UserTask的纔有數據)

SELECT * FROM `act_hi_taskinst`; #任務歷史表(只有節點是UserTask的時候該表存在數據)

SELECT * FROM `act_hi_actinst`; #全部活動節點的歷史表(其中包括任務也不包括任務)
#####################################################
#流程變量
SELECT * FROM `act_ru_variable`;#正在執行的流程變量表

SELECT * FROM `act_hi_varinst`; #歷史流程變量表

##################################################################
SELECT * FROM `act_ru_identitylink` #任務表(我的任務、組任務)

SELECT * FROM `act_hi_identitylink` #任務歷史表

#########################################################
SELECT * FROM `act_id_group` #角色表

SELECT * FROM `act_id_user` #用戶表

SELECT * FROM `act_id_membership` #用戶角色關聯表

 

6. 相關資料

  因爲學習上述的東西,我也是經過別人的視屏來學習,我以爲吧,視屏加手操真的是可以很快上手的呀。

  中文文檔Activiti 5.16 中文文檔:http://www.mossle.com/docs/activiti/index.html#chapterApi

  百度雲:http://pan.baidu.com/s/1gfmdCGj

  學習使用的代碼:https://git.oschina.net/flyPiglet/ActivitiStudy/      (個人碼雲、使用git方式能夠取得代碼)

平時上班比較忙,下次作個完整的,哈哈,加油Hikaru!

微信公衆號:努力編程的小豬

我雖然懶,可是程序員這個職業我仍是很喜歡的。

 

相關文章
相關標籤/搜索