springboot2整合activiti6过程总结

activiti6支持的springboot版本为1.2.6。由于版本比较老,所以需要对activiti6进行源码改造。步骤

一、在github上clone出activiti的源码,在activiti-6.0.0分支上创建并切换到新的分支

git checkout -b boot2 activiti-6.0.0

二、升级activiti版本,因为activiti已经发布了6.0.0版本,为了避免命名冲突,我们使用6.0.0-boot2

  1.    切换到activiti-spring-boot项目
    cd modules/activiti-spring-boot

    执行mvn命令,升级版本

    mvn versions:set -DnewVersion=6.0.0-boot2

    这是执行失败,失败的原因是没有指定activiti-spring-boot的版本号,所以我们需要在activiti-spring-boot新项目的pom.xml中指定版本6.0.0(直接在<parent>标签外添加<version>6.0.0</version>),再次执行mvn修改版本的命令,修改成功

  2. 版本升级后我们需要安装新版本,activiti-spring-boot项目下执行安装命令

    mvn clean install source:jar -Dmaven.test.skip=true

    此时执行是失败的,需要在activiti-spring-boot项目中全局查找${project.version}并替换成6.0.0(应该有18个)替换完成后再次执行安装,这次报错的原因是activiti-spring-boot-basic项目,这时可以在activiti-spring-boot-starter-basic项目的pom.xml文件中所有使用activiti相关的依赖都指定6.0.0版本,并在根pom.xml(activiti-root)中指定版本号,步骤是在根pom.xml 中添加<activiti.version>6.0.0</activiti.version>,查找${project.version}并替换成${activiti.version},这时再次执行安装命令是成功的

三、升级springboot版本

  1. 在activiti-spring-boot项目的pom.xml文件中将<spring.boot.version>1.2.6</spring.boot.version>修改成目标版版本,同时添加
    <spring.framework.version>5.0.4.RELEASE</spring.framework.version>
    <spring.security.version>5.0.3.RELEASE</spring.security.version>
    右击activiti-spring-boot选择Rebuild ...重现编译下项目。为了快速查找升级后项目的报错,在命令行切换到activiti-spring-boot项目,执行编译命令(若没有这个选项择说明项目还不是maven项目,需要右击pom.xml,然后Add As Maven Project)
  2. mvn clean test-compile

       此时根据报错一一解决

错误集中在这个文件夹下

ProcessEngineEndpoint类报错解决,将继承的AbstractEndpoint类去掉,同时注解也不是@ConfigurationProperties了,应该替换成@Endpoint(id="activiti"),去掉ProcessEngineEndpoint方法下的super,invoke方法替换成activiti同时将@Override注解去掉并添加新的注解@ReadOperation,删除多余的import

ProcessEngineMvcEndpoint类报错解决,将继承的EndpointMvcAdapter类去掉,添加

private final ProcessEngineEndpoint processEngineEndpoint;

  ProcessEngineMvcEndpoint方法的super去掉,添加

this.processEngineEndpoint = processEngineEndpoint;

去掉多余的import

EndpointAutoConfiguration类报错,直接去掉@ConditionalOnClass (name = "org.springframework.boot.actuate.endpoint.AbstractEndpoint")注解

SecurityAutoConfiguration类报错解决,SecurityAutoConfiguration.class包结构发生了变化,在SecurityAutoConfiguration添加上.servlet

@AutoConfigureBefore(org.springframework.boot.autoconfigure.security.servlet.SecurityAutoConfiguration.class)

去掉错误的import重新引入import

再次执行编译,发现spring-boot-sample-rest-api下的test包报错,由于是test,可以将报错的类注释掉

四、验证

新建springboot项目,引入activiti版本6.0.0-boot2,需要注意的是yml的数据库url一定要添加nullCatalogMeansCurrent=true,否则activiti表会创建失败

pom.xml

<?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 https://maven.apache.org/xsd/maven-4.0.0.xsd">
	<modelVersion>4.0.0</modelVersion>
	<parent>
		<groupId>org.springframework.boot</groupId>
		<artifactId>spring-boot-starter-parent</artifactId>
		<version>2.1.6.RELEASE</version>
		<relativePath/> <!-- lookup parent from repository -->
	</parent>
	<groupId>com.example</groupId>
	<artifactId>demo</artifactId>
	<version>0.0.1-SNAPSHOT</version>
	<name>demo</name>
	<description>Demo project for Spring Boot</description>

	<properties>
		<java.version>1.8</java.version>
	</properties>

	<dependencies>
		<dependency>
			<groupId>org.springframework.boot</groupId>
			<artifactId>spring-boot-starter-web</artifactId>
		</dependency>
		<dependency>
			<groupId>org.mybatis.spring.boot</groupId>
			<artifactId>mybatis-spring-boot-starter</artifactId>
			<version>2.1.1</version>
		</dependency>

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

		</dependency>
		<dependency>
			<groupId>org.springframework.boot</groupId>
			<artifactId>spring-boot-starter-test</artifactId>
			<scope>test</scope>
		</dependency>
		<dependency>
			<groupId>com.alibaba</groupId>
			<artifactId>druid</artifactId>
			<version>1.1.18</version>
		</dependency>
		<dependency>
			<groupId>org.activiti</groupId>
			<artifactId>activiti-spring-boot-starter-basic</artifactId>
			<version>6.0.0-boot2</version>
			<exclusions>
			<exclusion>
				<artifactId>slf4j-log4j12</artifactId>
				<groupId>org.slf4j</groupId>
			</exclusion>
		</exclusions>
		</dependency>
	</dependencies>

	<build>
		<plugins>
			<plugin>
				<groupId>org.springframework.boot</groupId>
				<artifactId>spring-boot-maven-plugin</artifactId>
			</plugin>
		</plugins>
	</build>

</project>

application.yml配置

server:
  port: 9999
spring:
  datasource:
    driver-class-name: com.mysql.cj.jdbc.Driver
    url: jdbc:mysql://192.168.0.112:3306/activiti_demo?useUnicode=true&characterEncoding=utf-8&useSSL=false&nullCatalogMeansCurrent=true
    username: root
    password: 123456
    #使用阿里巴巴druid数据源,默认使用自带的
    type: com.alibaba.druid.pool.DruidDataSource
  activiti:
    check-process-definitions: false
  liquibase:
    enabled: false

 

Spring Boot 2整合Activiti 7自动生成表结构是通过Activiti提供的数据库表自动生成脚本实现的。Activiti 7是基于Java的业务流程管理系统(BPM),它支持业务流程的定义、执行、监控和优化。在使用Spring Boot与Activiti 7集成时,可以通过配置和执行Activiti提供的初始化脚本来创建所需的数据库表结构。 以下是整合Activiti 7并自动生成表结构的基本步骤: 1. 添加依赖:首先需要在Spring Boot项目的`pom.xml`文件中添加Activiti相关的依赖,如下所示: ```xml <dependency> <groupId>org.activiti</groupId> <artifactId>activiti-spring-boot-starter-basic</artifactId> <version>7.0.0</version> </dependency> ``` 2. 配置数据源:在`application.properties`或`application.yml`配置文件中设置数据源信息,确保Activiti能够连接到数据库并执行表结构创建脚本。 ```properties spring.datasource.url=jdbc:mysql://localhost:3306/activiti spring.datasource.username=root spring.datasource.password=root spring.datasource.driver-class-name=com.mysql.cj.jdbc.Driver ``` 3. 自动执行脚本:Activiti 7默认情况下会根据数据库连接自动执行初始化脚本,创建所需的表结构。你可以在`application.properties`中配置`spring.activiti.init-mode`属性来控制初始化行为: ```properties spring.activiti.init-mode=always ``` 其中`init-mode`有三个可选值: - `never`:不自动执行初始化脚本。 - `embedded`:在使用内置的数据库时自动执行初始化脚本。 - `always`:无论数据库类型,总是执行初始化脚本。 4. 启动Spring Boot应用:启动你的Spring Boot应用程序,Activiti会在应用启动时自动创建所需的表结构。 为了确保整个过程的正确性和安全性,建议在非生产环境下进行测试和验证,以及对数据库进行备份。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值