[ Flowable ] 与modeler流程设计器整合教程

2023-12-22 01:48

本文主要是介绍[ Flowable ] 与modeler流程设计器整合教程,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

Flowable 与 modeler 流程设计器整合方案

本教程基于Flowable 6.2.1 ,破解 flowable-idm的权限登录,整合SpringMVC实现maven动态导入jar包,期间遇坑无数,写下此文,还望对各位学习工作流的小伙伴有所帮助!


一、准备工作

1、flowable-modeler 获取

这里写图片描述
下载链接>>>

2、资源文件解压并导入SpringMVC项目

这里写图片描述

/** 配置静态资源路由*/
<!-- don't handle the static resource -->
<mvc:default-servlet-handler />
<!-- if you use annotation you must configure following setting -->
<mvc:annotation-driven /><!-- 静态资源文件映射,不会被Spring MVC拦截 -->
<mvc:resources mapping="/js/**" location="/static/js/"/>
<mvc:resources mapping="/css/**" location="/static/css/"/>
<mvc:resources mapping="/plugin/**" location="/static/plugin/"/>
<mvc:resources mapping="/images/**" location="/static/images/"/>
<mvc:resources mapping="/resource/**" location="/static/resource/"/>
<mvc:resources mapping="/html/**" location="/static/html/"/>
<mvc:resources mapping="/swagger/**" location="/swagger/"/>
<mvc:resources mapping="/modeler/**" location="/modeler/"/>

3、调整flowable-modeler前端访问路径

这里写图片描述

4、模拟登录接口(破解idm的权限校验)

  • 后台登录(可在此处向己方人员系统做切换,前端缓存人员token信息或是利用session皆可)
package cn.com.showclear.activiti.controller.data;import cn.com.showclear.common.resp.RespMapJson;
import com.wordnik.swagger.annotations.Api;
import com.wordnik.swagger.annotations.ApiOperation;
import org.flowable.idm.pojo.AppUser;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;/*** 模拟登录* @author YF-XIACHAOYANG* @date 2018/1/30 11:18*/
@RestController
@RequestMapping("/data/modeler/")
public class FlowableModelerRestController {@RequestMapping("account")  public RespMapJson account() {AppUser user = new AppUser("2017","activiti","scooper","scooper-activiti");return new RespMapJson().setData(user);}
}
  • 前端登录接口替换

这里写图片描述

二、app-rest接口导入和破解

由于flowable-modeler的流程设计器页面很多操作会访问后台接口,在非maven的框架下,有人是通过导入jar包来实现的,在maven的框架下,我采用导入jar包源码并覆盖扫描的方式来实现后台servlet接口的实现。

1、pom

<!--流程设计器-->
<dependency><groupId>org.flowable</groupId><artifactId>flowable-ui-modeler-rest</artifactId><version>${flowable.version}</version>
</dependency><!--路由配置-->
<dependency><groupId>org.flowable</groupId><artifactId>flowable-ui-modeler-conf</artifactId><version>${flowable.version}</version>
</dependency>

2、源码覆盖二度扫描注入

解决扫描注入失败的问题,解决部分接口和配置文件加载路径调整的问题,其他可能涉及到需要修改接口的问题。

> 源码导入(方便复写)

这里写图片描述

> web.xml 添加路由映射
/*在web.xml中添加路由映射*/
<!-- 配置Spring核心控制器 -->
<servlet><servlet-name>springmvc</servlet-name><servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class><!--可以不配置.默认所对应的配置文件是WEB-INF下的{servlet-name}-servlet.xml,这里便是:spring-servlet.xml--><init-param><param-name>contextConfigLocation</param-name><param-value>classpath:/config/spring/spring-servlet.xml</param-value></init-param><load-on-startup>1</load-on-startup></servlet><!--这里可以用 / 但不能用 /*,拦截了所有请求会导致静态资源无法访问,所以要在spring-servlet.xml中配置mvc:resources--><servlet-mapping><servlet-name>springmvc</servlet-name><url-pattern>/</url-pattern></servlet-mapping><!-- 配置floeable-app-rest控制器 --><servlet><servlet-name>appDispatcherServlet</servlet-name><servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class><!--可以不配置.默认所对应的配置文件是WEB-INF下的{servlet-name}-servlet.xml,这里便是:spring-servlet.xml--><init-param><param-name>contextConfigLocation</param-name><param-value>classpath:/config/flowable/app-servlet.xml</param-value></init-param><load-on-startup>1</load-on-startup></servlet><servlet-mapping><servlet-name>appDispatcherServlet</servlet-name><url-pattern>/app/*</url-pattern></servlet-mapping>
> 添加配置:扫描注入

这里写图片描述

> 汉化:主要是修改stencilset_bpmn.json文件(百度一下可以找到很多)

这里写图片描述

效果:

这里写图片描述

这里写图片描述

这里写图片描述

备注

1、数据库操作请使用c3p0,因为flowable-modeler中使用的是这个,避免冲突。
2、由于静态资源在项目中,所以样式的修改完全可以自定义。

参考

# 基本知识1、c3p0 Spring 配置http://blog.csdn.net/l1028386804/article/details/511625602、Flowable基础五 Flowable 数据库配置http://www.shareniu.com/article/98.htm3、[ github ] flowable-enginehttps://github.com/flowable/flowable-engine/tree/flowable-6.2.14、flowable使用http://www.shareniu.com/article/19.htm5、flowable 集成spring boothttp://www.shareniu.com/article/81.htm6、Flowable基础十四 Flowable modeler汉化http://www.shareniu.com/article/108.htm7、Flowable无法登录http://www.shareniu.com/article/174.htm8、flowable 官网http://www.flowable.org/9、activiti自定义流程之Spring整合activiti-modeler实例(一):环境搭建http://blog.csdn.net/hj7jay/article/details/5114902610、如何整合Flowable-modeler到自己的项目中http://veevv.com/2017/03/17/flowable-modeler-integrate/11、springboot整合flowablehttp://blog.csdn.net/zl1zl2zl3/article/details/7892116212、flowable与modeler整合http://www.shareniu.com/article/52.htm13、取消验证http://veevv.com/2017/03/17/flowable-modeler-integrate/14、国际化https://www.cnblogs.com/liukemng/p/3750117.html# 通用1、maven 源码http://www.mvnjar.com/2、手册https://tkjohn.github.io/flowable-userguide/

更多

扫码关注“架构探险之道”,获取更多源码和文章资源

在这里插入图片描述

知识星球(扫码加入获取源码和文章资源链接)

在这里插入图片描述


加入“知识星球”直接获取源码

Tips

  1. 此处导入的源码是针对需要修改的conf、rest部分的代码

  2. 分享的链接在整合前请先整体浏览下,本文主要是介绍思路来源和实现方案介绍(个人觉得思路非常重要)


20190331

  • 增加最新Flowable 6.4.1和Spring Boot 整合流程设计器的源码[含鉴权破解、汉化](知识星球)
    文章链接点这里>>>>
  • 上传Spring MVC和Flowable Modeler 破解源码(知识星球)

这篇关于[ Flowable ] 与modeler流程设计器整合教程的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/522215

相关文章

springboot整合 xxl-job及使用步骤

《springboot整合xxl-job及使用步骤》XXL-JOB是一个分布式任务调度平台,用于解决分布式系统中的任务调度和管理问题,文章详细介绍了XXL-JOB的架构,包括调度中心、执行器和Web... 目录一、xxl-job是什么二、使用步骤1. 下载并运行管理端代码2. 访问管理页面,确认是否启动成功

使用Nginx来共享文件的详细教程

《使用Nginx来共享文件的详细教程》有时我们想共享电脑上的某些文件,一个比较方便的做法是,开一个HTTP服务,指向文件所在的目录,这次我们用nginx来实现这个需求,本文将通过代码示例一步步教你使用... 在本教程中,我们将向您展示如何使用开源 Web 服务器 Nginx 设置文件共享服务器步骤 0 —

Golang使用minio替代文件系统的实战教程

《Golang使用minio替代文件系统的实战教程》本文讨论项目开发中直接文件系统的限制或不足,接着介绍Minio对象存储的优势,同时给出Golang的实际示例代码,包括初始化客户端、读取minio对... 目录文件系统 vs Minio文件系统不足:对象存储:miniogolang连接Minio配置Min

SpringBoot使用minio进行文件管理的流程步骤

《SpringBoot使用minio进行文件管理的流程步骤》MinIO是一个高性能的对象存储系统,兼容AmazonS3API,该软件设计用于处理非结构化数据,如图片、视频、日志文件以及备份数据等,本文... 目录一、拉取minio镜像二、创建配置文件和上传文件的目录三、启动容器四、浏览器登录 minio五、

手把手教你idea中创建一个javaweb(webapp)项目详细图文教程

《手把手教你idea中创建一个javaweb(webapp)项目详细图文教程》:本文主要介绍如何使用IntelliJIDEA创建一个Maven项目,并配置Tomcat服务器进行运行,过程包括创建... 1.启动idea2.创建项目模板点击项目-新建项目-选择maven,显示如下页面输入项目名称,选择

SpringBoot整合kaptcha验证码过程(复制粘贴即可用)

《SpringBoot整合kaptcha验证码过程(复制粘贴即可用)》本文介绍了如何在SpringBoot项目中整合Kaptcha验证码实现,通过配置和编写相应的Controller、工具类以及前端页... 目录SpringBoot整合kaptcha验证码程序目录参考有两种方式在springboot中使用k

Python基于火山引擎豆包大模型搭建QQ机器人详细教程(2024年最新)

《Python基于火山引擎豆包大模型搭建QQ机器人详细教程(2024年最新)》:本文主要介绍Python基于火山引擎豆包大模型搭建QQ机器人详细的相关资料,包括开通模型、配置APIKEY鉴权和SD... 目录豆包大模型概述开通模型付费安装 SDK 环境配置 API KEY 鉴权Ark 模型接口Prompt

在 VSCode 中配置 C++ 开发环境的详细教程

《在VSCode中配置C++开发环境的详细教程》本文详细介绍了如何在VisualStudioCode(VSCode)中配置C++开发环境,包括安装必要的工具、配置编译器、设置调试环境等步骤,通... 目录如何在 VSCode 中配置 C++ 开发环境:详细教程1. 什么是 VSCode?2. 安装 VSCo

Spring Boot 中整合 MyBatis-Plus详细步骤(最新推荐)

《SpringBoot中整合MyBatis-Plus详细步骤(最新推荐)》本文详细介绍了如何在SpringBoot项目中整合MyBatis-Plus,包括整合步骤、基本CRUD操作、分页查询、批... 目录一、整合步骤1. 创建 Spring Boot 项目2. 配置项目依赖3. 配置数据源4. 创建实体类

Linux下MySQL8.0.26安装教程

《Linux下MySQL8.0.26安装教程》文章详细介绍了如何在Linux系统上安装和配置MySQL,包括下载、解压、安装依赖、启动服务、获取默认密码、设置密码、支持远程登录以及创建表,感兴趣的朋友... 目录1.找到官网下载位置1.访问mysql存档2.下载社区版3.百度网盘中2.linux安装配置1.