91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

Activiti工作流從入門到入土:入門實例

發布時間:2020-07-26 22:01:08 來源:網絡 閱讀:400 作者:歐陽思海 欄目:編程語言

文章源碼托管:https://github.com/OUYANGSIHAI/Activiti-learninig
歡迎 star !!!

一、前言

在上一節中我們對activiti進行了基本的介紹activiti進行了基本的介紹,同時介紹了基本的概念。

這一節,我將用一個入門程序,介紹如何使用activiti。

二、環境準備

2.1、編譯器選擇

這里我們使用Idea進行工作流開發,雖然Idea對于工作流的友好度不是很好,因為會有一些小的bug,但是,Idea對于Java的開發還是非常的好的。

在用Idea開發之前,我們需要在idea中安裝bpmn開發的插件。方法如下

打開設置

Activiti工作流從入門到入土:入門實例

選擇plugins
Activiti工作流從入門到入土:入門實例

搜索actiBPM
Activiti工作流從入門到入土:入門實例

重啟idea,新建文件

如果能夠找到下面的創建方法,就代表成功了。
Activiti工作流從入門到入土:入門實例

新建后出現下面的編輯頁面
Activiti工作流從入門到入土:入門實例

到現在,bpmn編輯插件就準備好了。

2.2、其他環境準備
  • JDK:1.8
  • 數據庫:mysql5.7
  • activiti jar包:使用maven依賴

三、入門程序

3.1、新建maven項目

新建的maven項目目錄如下
Activiti工作流從入門到入土:入門實例

3.2、添加pom依賴

這里需要的pom依賴有以下幾個:junit、druid、mysql、lombok(日志)、activiti

<?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.sihai</groupId>
    <artifactId>acitvitiDemo</artifactId>
    <version>1.0-SNAPSHOT</version>

    <properties>
        <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
        <maven.compiler.source>1.8</maven.compiler.source>
        <maven.compiler.target>1.8</maven.compiler.target>
    </properties>

    <dependencies>
        <dependency>
            <groupId>junit</groupId>
            <artifactId>junit</artifactId>
            <version>4.12</version>
            <scope>test</scope>
        </dependency>

        <!-- druid -->
        <dependency>
            <groupId>com.alibaba</groupId>
            <artifactId>druid</artifactId>
            <version>1.1.12</version>
        </dependency>

        <!-- mysql -->
        <dependency>
            <groupId>mysql</groupId>
            <artifactId>mysql-connector-java</artifactId>
            <version>5.1.30</version>
        </dependency>

        <!-- lombok -->
        <dependency>
            <groupId>org.projectlombok</groupId>
            <artifactId>lombok</artifactId>
            <version>1.16.12</version>
        </dependency>

        <!-- logback -->
        <dependency>
            <groupId>ch.qos.logback</groupId>
            <artifactId>logback-core</artifactId>
            <version>1.1.8</version>
        </dependency>
        <dependency>
            <groupId>ch.qos.logback</groupId>
            <artifactId>logback-classic</artifactId>
            <version>1.1.8</version>
        </dependency>
        <dependency>
            <groupId>org.slf4j</groupId>
            <artifactId>slf4j-api</artifactId>
            <version>1.7.22</version>
        </dependency>

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

    <build>
        <pluginManagement><!-- lock down plugins versions to avoid using Maven defaults (may be moved to parent pom) -->
            <plugins>
                <plugin>
                    <groupId>org.apache.maven.plugins</groupId>
                    <artifactId>maven-compiler-plugin</artifactId>
                    <configuration>
                        <source>1.8</source>
                        <target>1.8</target>
                    </configuration>
                </plugin>
            </plugins>
        </pluginManagement>
    </build>
</project>
3.3、日志配置文件
<?xml version="1.0" encoding="UTF-8"?>
<configuration scan="true" scanPeriod="60 seconds">

    <appender name="STDOUT" class="ch.qos.logback.core.ConsoleAppender">
        <encoder>
            <pattern>%d{yyyy-MM-dd HH:mm:ss.SSS} [%thread] %-5level %logger - %msg%n</pattern>
        </encoder>
    </appender>

    <!--<appender name="permission" class="ch.qos.logback.core.rolling.RollingFileAppender">-->
    <!--<file>${catalina.home}/logs/permission.log</file>-->
    <!--<rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">-->
    <!--<FileNamePattern>${catalina.home}/logs/permission.%d{yyyy-MM-dd}.log.gz</FileNamePattern>-->
    <!--</rollingPolicy>-->
    <!--<layout class="ch.qos.logback.classic.PatternLayout">-->
    <!--<pattern>%d{yyyy-MM-dd HH:mm:ss.SSS} [%thread] %-5level %logger - %msg%n</pattern>-->
    <!--</layout>-->
    <!--</appender>-->
    <!---->
    <!--<logger name="xxx" level="INFO">-->
    <!--<appender-ref ref="permission"/>-->
    <!--</logger>-->

    <!-- TRACE < DEBUG < INFO < WARN < ERROR -->
    <root level="INFO">
        <appender-ref ref="STDOUT"/>
    </root>

</configuration>
3.4、測試實例

下面是添加一個junit測試實例,通過測試生成activiti底層需要的數據庫表,總共有25張,如果數據庫生成了25張表結構,則說明成功!

/**
 * @Author ouyangsihai
 * @Description 生成activiti底層數據庫表結構
 * @Date 16:24 2019/1/26
 * @Param
 * @return
 **/
public class Activiti_01 {
    /**
     * @return void
     * @Author ouyangsihai
     * @Description //生成數據庫表結構
     * @Date 20:57 2018/12/5
     * @Param []
     **/
    @Test
    public void test_createDatabase() {
        // 創建流程引擎配置信息對象
        ProcessEngineConfiguration pec = ProcessEngineConfiguration
                .createStandaloneProcessEngineConfiguration();
        // 設置數據庫的類型
        pec.setDatabaseType("mysql");
        // 設置創建數據庫的方式
//        ProcessEngineConfiguration.DB_SCHEMA_UPDATE_TRUE(true);//如果沒有數據庫表就會創建數據庫表,有的話就修改表結構.
        // ProcessEngineConfiguration.DB_SCHEMA_UPDATE_FALSE(false): 不會創建數據庫表
        // ProcessEngineConfiguration.DB_SCHEMA_UPDATE_CREATE_DROP(create-drop): 先創建、再刪除.
        pec.setDatabaseSchemaUpdate("true");
        // 設置數據庫驅動
        pec.setJdbcDriver("com.mysql.jdbc.Driver");
        // 設置jdbcURL
        pec.setJdbcUrl("jdbc:mysql://localhost:3306/activitiTest?useUnicode=true&characterEncoding=UTF-8");
        // 設置用戶名
        pec.setJdbcUsername("root");
        // 設置密碼

        pec.setJdbcPassword("root");

        pec.setJdbcPassword("XXXX");

        // 構建流程引擎對象
        ProcessEngine pe = pec.buildProcessEngine(); // 調用訪方法才會創建數據表
        // 調用close方法時,才會刪除
        pe.close();
    }
}
3.5、運行測試實例

運行上面的測試實例后,將會生成下面的25張表結構。

日志信息
Activiti工作流從入門到入土:入門實例

表結構
Activiti工作流從入門到入土:入門實例

四、總結

通過上面是入門實例,就將activiti的環境準備好了!

文章有不當之處,歡迎指正,如果喜歡微信閱讀,你也可以關注我的微信公眾號好好學java,獲取優質學習資源。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

密云县| 宜州市| 陵川县| 武汉市| 株洲市| 东至县| 万宁市| 龙山县| 霍林郭勒市| 诸暨市| 文安县| 云梦县| 玉龙| 京山县| 澄城县| 浠水县| 道孚县| 龙游县| 工布江达县| 淮北市| 万载县| 宜良县| 沙湾县| 和硕县| 玉田县| 乌鲁木齐县| 元氏县| 彭阳县| 昌都县| 中方县| 乌兰察布市| 郯城县| 怀来县| 蓬溪县| 瓦房店市| 内丘县| 自治县| 乐业县| 濮阳县| 保亭| 张家港市|