Activiti使用工作流SpringBoot整合Activiti
文章目录
-
- Activiti使用工作流SpringBoot整合Activiti
-
-
- 一、springboot整合Activiti环境依赖
-
- 1.1 maven环境
- 1.2 添加日志配置
- 1.3 添加activiti配置文件
- 二、流程操作-流程模型
-
- 2.1 绘制流程模型编辑器
- 2.2 创建模型
- 2.3 查询流程模型模板
- 2.4 删除流程定义模板
- 2.5 导出模型zip方式
- 2.6 部署流程
- 三、流程操作-流程部署
-
- 3.1 部署流程
- 3.2 删除部署信息
- 3.3 查询部署的流程定义数据
- 3.4 或定义激活过程
- 3.5 导出过程定义相关文件
- 四、流程操作-流程实例
-
- 4.1 启动流程
- 4.2 查询正在运行的流程实例
- 4.3 挂起或激活过程实例
- 4.4 删除流程实例
- 4.5 查询已完成的流程实例
- 五、流程操作-流程任务
-
- 5.1 查询当前用户代理人或候选人的任务
- 5.2 获取下一个节点任务
- 5.3 如果有排他性或平行网关,需要获取当前的审批节点来设置下一个节点处理器。
- 5.4 签收任务
- 5.5 任务转交
- 5.6 完成任务
- 5.7 设置下一个节点人
- 5.8 节点跳转已完成的任务
- 5.9 节点跳转
- 六、流程操作-流程历史
-
- 6.1 查询审批历史记录
- 6.2 获取审批历史记录图
- 6.3 查询指定用户已处理的任务
- 6.4 删除已完成的流程实例
-
一、springboot整合Activiti环境依赖
1.1 maven环境
<?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.mengxuegu</groupId> <artifactId>activiti-boot</artifactId> <version>1.0-SNAPSHOT</version> <parent> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-parent</artifactId> <version>2.5.0</version> <relativePath/> </parent> <properties> <activiti.version>7.1.0.M6</activiti.version> <mybatis-plus.version>3.3.1</mybatis-plus.version> </properties> <dependencies> <!-- Activiti --> <dependency> <groupId>org.activiti</groupId> <artifactId>activiti-spring-boot-starter</artifactId> <version>${activiti.version}</version> </dependency> <!-- java绘制activiti流程图 --> <dependency> <groupId>org.activiti</groupId> <artifactId>activiti-image-generator</artifactId> <version>${activiti.version}</version> </dependency> <!-- activiti json转换器--> <dependency> <groupId>org.activiti</groupId> <artifactId>activiti-json-converter</artifactId> <version>${activiti.version}</version> </dependency> <!-- svg转png图片工具--> <dependency> <groupId>org.apache.xmlgraphics</groupId> <artifactId>batik-all</artifactId> <version>1.10</version> </dependency> <!-- web启动器--> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-web</artifactId> </dependency> <dependency> <groupId>mysql</groupId> <artifactId>mysql-connector-java</artifactId> </dependency> <!--mybatis-plusǷ--> <dependency> <groupId>com.baomidou</groupId> <artifactId>mybatis-plus-boot-starter</artifactId> <version>${mybatis-plus.version}</version> </dependency> <!-- SpringSecurity --> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-security</artifactId> </dependency> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-test</artifactId> <scope>test</scope> </dependency> <dependency> <groupId>org.projectlombok</groupId> <artifactId>lombok</artifactId> <version>1.18.20</version> </dependency> <dependency> <groupId>commons-io</groupId> <artifactId>commons-io</artifactId> <version>2.6</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> </dependencies> <build> <plugins> <plugin> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-maven-plugin</artifactId> </plugin> </plugins> </build> </project>
1.2 添加日志配置
##我们使用log4j日志包,可以对日志进行配置,在resources 下创建log4j.properties # Set root category priority to INFO and its only appender to CONSOLE. #log4j.rootCategory=INFO, CONSOLE debug info warn error fatal log4j.rootCategory=debug, CONSOLE, LOGFILE # Set the enterprise logger category to FATAL and its only appender to CONSOLE. log4j.logger.org.apache.axis.enterprise=FATAL, CONSOLE # CONSOLE is set to be a ConsoleAppender using a PatternLayout. log4j.appender.CONSOLE=org.apache.log4j.ConsoleAppender log4j.appender.CONSOLE.layout=org.apache.log4j.PatternLayout log4j.appender.CONSOLE.layout.ConversionPattern=%d{ISO8601} %-6r[%15.15t] %-5p %30.30c %x - %m\n # LOGFILE is set to be a File appender using a PatternLayout. log4j.appender.LOGFILE=org.apache.log4j.FileAppender log4j.appender.LOGFILE.File=f:\act\activiti.log log4j.appender.LOGFILE.Append=true log4j.appender.LOGFILE.layout=org.apache.log4j.PatternLayout log4j.appender.LOGFILE.layout.ConversionPattern=%d{ISO8601} %-6r[%15.15t] %-5p %30.30c %x - %m\n
1.3 添加activiti配置文件
直接使用application.yaml配置
server: port: 9889 servlet: context-path: /com/act spring: mvc: static-path-pattern: /** cloud: nacos: discovery: server-addr: 填写自己地址 datasource: druid: 配置自己数据库连接 # 初始化大小,最小,最大 initial-size: 1 min-idle: 3 max-active: 20 # 配置获取连接等待超时的时间 max-wait: 6000 # activiti配置 activiti: #自动更新数据库结构 # true:适用开发环境,默认值。activiti会对数据库中所有表进行更新操作。如果表不存在,则自动创建 # false:适用生产环境。activiti在启动时,对比数据库表中保存的版本,如果没有表或者版本不匹配,将抛出异常 # create_drop: 在activiti启动时创建表,在关闭时删除表(必须手动关闭引擎,才能删除表) # drop-create: 在activiti启动时删除原来的旧表,然后在创建新表(不需要手动关闭引擎) database-schema-update: false # activiti7与springboot整合后默认不创建历史表,需要手动开启 db-history-used: true # 记录历史等级 可配置的历史级别有none, activity, audit, full # none:不保存任何的历史数据,因此,在流程执行过程中,这是最高效的。 # activity:级别高于none,保存流程实例与流程行为,其他数据不保存。 # audit:除activity级别会保存的数据外,还会保存全部的流程任务及其属性。 # full:保存历史数据的最高级别,除了会保存audit级别的数据外,还会保存其他全部流程相关的细节数据,包括一些流程参数等。 history-level: full # 是否自动检查resources下的processes目录的流程定义文件 check-process-definitions: false # # smtp服务器地址 # mail-server-host: # # SSL端口号 # mail-server-port: # # 开启ssl协议 # mail-server-use-ssl: true # # 默认的邮件发送地址(发送人),如果activiti流程定义中没有指定发送人,则取这个值 # mail-server-default-from: # # 邮件的用户名 # mail-server-user-name: deployment-mode: never-fail logging: level: com: oneconnect: sg: debug # 日志级别是debug才能显示SQL日志 org.activiti.engine.impl.persistence.entity: inf mybatis-plus: type-aliases-package: com.act.entity # xxxMapper.xml 路径 mapper-locations: classpath*:com/act/mapper/**/*.xml
二、流程操作–流程模型
2.1 绘制流程模型编辑器
- ModelEditorJsonRestResource
package com.oneconnect.sg.act.activiti; import org.activiti.editor.constants.ModelDataJsonConstants; import org.activiti.engine.ActivitiException; import org.activiti.engine.RepositoryService; import org.activiti.engine.repository.Model; import org.apache.commons.lang3.StringUtils; import org.slf4j.Logger; import org.slf4j.LoggerFactory; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.web.bind.annotation.PathVariable; import org.springframework.web.bind.annotation.RequestMapping; import org.springframework.web.bind.annotation.RequestMethod; import org.springframework.web.bind.annotation.RestController; import com.fasterxml.jackson.databind.ObjectMapper; import com.fasterxml.jackson.databind.node.ObjectNode; /** * */ @RestController public class ModelEditorJsonRestResource implements ModelDataJsonConstants { protected static final Logger LOGGER = LoggerFactory.getLogger(ModelEditorJsonRestResource.class); @Autowired private RepositoryService repositoryService; @Autowired private ObjectMapper objectMapper; @RequestMapping(value="/model/{modelId}/json", method = RequestMethod.GET, produces = "application/json") public ObjectNode getEditorJson(@PathVariable String modelId) { ObjectNode modelNode = null; Model model = repositoryService.getModel(modelId); if (model != null) { try { if (StringUtils.isNotEmpty(model.getMetaInfo())) { modelNode = (ObjectNode) objectMapper.readTree(model.getMetaInfo()); } else { modelNode = objectMapper.createObjectNode(); modelNode.put(MODEL_NAME, model.getName()); } modelNode.put(MODEL_ID, model.getId()); ObjectNode editorJsonNode = (ObjectNode) objectMapper.readTree( new String(repositoryService.getModelEditorSource(model.getId()), "utf-8")); modelNode.put("model", editorJsonNode); } catch (Exception e) { LOGGER.error("Error creating model JSON", e); throw new ActivitiException("Error creating model JSON", e); } } return modelNode; } }
package com.oneconnect.sg.act.activiti; import com.fasterxml.jackson.databind.ObjectMapper; import com.fasterxml.jackson.databind.node.ObjectNode; import org.activiti.editor.constants.ModelDataJsonConstants; import org.activiti.engine.ActivitiException; import org.activiti.engine.RepositoryService; import org.activiti.engine.repository.Model; import org.apache.batik.transcoder.TranscoderInput; import org.apache.batik.transcoder.TranscoderOutput; import org.apache.batik.transcoder.image.PNGTranscoder; import org.slf4j.Logger; import org.slf4j.LoggerFactory; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.http.HttpStatus; import org.springframework.util.MultiValueMap; import org.springframework.web.bind.annotation.*; import java.io.ByteArrayInputStream; import java.io.ByteArrayOutputStream; import java.io.InputStream; /** * */ @RestController public class ModelSaveRestResource implements ModelDataJsonConstants { protected static final Logger LOGGER = LoggerFactory.getLogger(ModelSaveRestResource.class); @Autowired private RepositoryService repositoryService; @Autowired private ObjectMapper objectMapper; @RequestMapping(value="/model/{modelId}/save", method = RequestMethod.PUT) @ResponseStatus(value = HttpStatus.OK) public void saveModel(@PathVariable String modelId, @RequestParam MultiValueMap<String, String> values) { try { Model model = repositoryService.getModel(modelId); ObjectNode modelJson = (ObjectNode) objectMapper.readTree(model.getMetaInfo()); modelJson.put(MODEL_NAME, values.getFirst("name")); modelJson.put(MODEL_DESCRIPTION, values.getFirst("description")); model.setMetaInfo(modelJson.toString()); model.setName(values.getFirst("name")); // 每次修改模型保存后,将版本号+1 model.setVersion(model.getVersion()+1); ObjectNode jsonXml = (