49张图带领小伙伴们体验一把 Flowable-UI

简介: 49张图带领小伙伴们体验一把 Flowable-UI

不知道小伙伴们有没发发现,IDEA 中似乎没有一个特别称手的流程绘制工具,大家注意我说的是称手,不是能用。

我之前用过下图这个插件:

562588f33e18f32e6e5d5809f634406d.png评价就是两个字:能用!

官方提供了一个 flowable-ui,功能还比较强大,可以一试,今天我就来和小伙伴们简单介绍一下这个 flowable-ui 的使用,用熟了,将来我们可以使用这个来绘制流程图。

1. Flowable-UI

Flowable-UI 说白了就是一堆 Web 应用,提供了四方面的功能:

Flowable IDM: 身份管理应用。为所有 Flowable UI 应用提供单点登录认证功能,并且为拥有 IDM 管理员权限的用户提供了管理用户、组与权限的功能。

Flowable Modeler: 让具有建模权限的用户可以创建流程模型、表单、选择表与应用定义。

Flowable Task: 运行时任务应用,这个提供了启动流程实例、编辑任务表单、完成任务,以及查询流程实例与任务的功能。

Flowable Admin: 管理应用。让具有管理员权限的用户可以查询 BPMN、DMN、Form 及 Content 引擎,并提供了许多选项用于修改流程实例、任务、作业等。管理应用通过 REST API 连接至引擎,并与 Flowable Task 应用及 Flowable REST 应用一同部署。

简单来说:

  • 创建用户、分配角色用 Flowable IDM。
  • 画流程图用户 Flowable Modeler。
  • 测试、体验流程用 Flowable Task。
  • 后台管理相关的用 Flowable Admin。

2. 安装方式

前面说的几个应用,所有其他的应用都需要 Flowable IDM 提供认证。每个应用的 WAR 文件可以部署在相同的 Servlet 容器(如Apache Tomcat)中,也可以部署在不同的容器中。由于每个应用使用相同的 cookie 进行认证,因此应用需要运行在相同的域名下。

由于这些应用是基于 Spring Boot2.0 开发的,因此也可以直接作为独立应用来直接运行,通过执行 java -jar xxx.war 的方式来启动这些应用。

所以直接启动这些应用并不是麻烦事,反而是比较简单的。不过我看了下他这个还支持 Docker 安装,所以我还是用 Docker 吧,更省事,将来不想要了删除也方便(对 Docker 不熟悉的小伙伴可以在微信公众号后台回复 docker,有松哥写的入门教程)。

docker 安装的话,直接如下命令即可:

docker run -d --name flowableui -p 8086:8080 flowable/flowable-ui

没什么特别需要配置的地方,指定一下容器名字和端口映射即可。

b6e403f3b462080cefc822df2e88e0a2.png

装好之后,浏览器输入 http://localhost:8086/flowable-ui 进行访问,此时会弹出来如下页面:

a1996b83bb130c25781bb8f180703ce6.png默认情况下,登录的用户名是 admin,密码是 test,注意别把密码写错了。

登录成功之后,如果看到如下页面,就表示安装成功了(一般来说应该不会有安装问题):


f53da13afeaf25b7e59ac83cca96cce6.png

装好之后,接下来我们就来逐步体验这里的功能,我从简单的开始讲起。

3. 身份管理(IDM)

身份管理就是用户、用户组的管理,我们点进到身份管理页面之后,可以看到如下内容:

cb446ee7b462249e9b536f9d0525403d.png

可以看到,默认只有一个 admin 用户,也就是我们刚刚登录时候的用户。

3.1 用户管理

接下来点击左边的创建用户按钮,我们可以创建新的用户出来:

065306a9ee1ce5232e7ae3e95cef408c.png

填入用户的基本信息和密码即可。

我一共创建了四个用户,最终结果如下:

199693729dfe9c2b8e395c87830f0954.png

3.2 组管理

接下来点击上面的,我们可以创建用户组,这个用户组相当于我们在 vhr 中所说的角色,给用户分组,相当于给用户分配一个角色。

默认情况下,没有任何组,组是空的:

c3e156f28efdd287971c699e390ebe35.png

我们点击创建组按钮,先来创建一个经理组:

ddcbc54113449d85123a911b84e5be42.png

组添加成功之后,点击添加用户按钮,为用户组中添加用户:

bade56049993bae62cc4b28bb322ed98.png

假设 zhangsan 和 zhangsi 两个人是经理,最终添加结果如下:

bb54468f4a57a8f3952dd12f3fb7a92b.png

利用相同的方式,我再创建一个组长的组,并为之添加两个用户 lisi 和 liwu。

48c83455bf420f2f1aa5d0fa0e193491.png

3.3 权限控制

我们前面创建的用户现在是没有任何权限的,例如现在如果使用 zhangsan/123 进行登录,登录成功后页面是空的,没有任何东西:

26306261c27a1009b87dc50b697a2096.png

所以我们要为用户添加相应的权限。点击顶部的权限控制一栏,如下:

bfeb8042b6b172f700ed9d7329cfcb3e.png

我们可以为这五种访问分别设置对应的用户/用户组:

访问 idm 应用:这个就是访问身份管理应用,如果用户没有访问这个的权限,那么用户在登录成功的后的首页上就看不到身份管理应用程序这个菜单项。

访问 admin 应用:这个是访问管理员应用程式,如果没有没有这个的访问权限,那么用户在登录成功之后的首页上就看不到管理员应用程式这个菜单项。

访问 modeler 应用:这个是访问建模器应用程序,如果没有没有这个的访问权限,那么用户在登录成功之后的首页上就看不到建模器应用程序这个菜单项。

访问 workflow 应用:这个是访问任务应用程序,如果没有没有这个的访问权限,那么用户在登录成功之后的首页上就看不到任务应用程序这个菜单项。

访问 REST API:这个是指用户通过 REST API 访问工作流的权限。

以访问 idm 应用为例,在设置的时候,我们可以直接设置用户,也可以设置用户组,设置用户组的话,则这个组中的所有用户都能访问这个菜单项。


527da6362d84b5108232aa72be9b1411.png

我这里设置的是经理可以访问所有应用,而组长只可以访问 workflow 应用。


97a6b6c6d36a4251306e6a3fabdc600a.png

4. 管理员(Admin)

接下来是管理员应用程式,这个里边的功能相对来说简单一些,而且主要是数据查看,需要自己配置的比较少:

ad7face27477a5ebb2a72f829fd5e3e5.png

这是一个总览的页面,上面有流程引擎、CMMN引擎、App 引擎等各种菜单。这个因为用的不多,我也就不啰嗦了,小伙伴们可以自行体验一把。

5. 建模器(Modeler)

接下来的建模器算是我们在使用 Flowable-UI 时最最常用的功能了,因为画流程图就是在这里画。

5.1 绘制流程图

0cc6fc119ee48183770598235427db9d.png

点击创建流程,可以开始一个流程图的绘制:

15e72a81e82287d7f79737653380af27.png

我们来看一下初始页面:

227f41ff49b2a063619e229f3c4a3c45.png

左边是菜单栏,里边是绘制流程图的各种组件,下边是流程图的各种属性了。其他东西大家看一下就懂了,我就不多说了。下边没有什么需要配置的,我就设置了一下版本号。

接下来我绘制一个简单的流程,如下图(一个流程启动之后,经过两个 UserTask 然后就结束了):

52700e76480bb17b9e6bb2ce7806e2bf.png绘制的时候,光标放在上一个组件上,然后会自动提示后面的组件,直接点击即可:


9ef62890782375e64b4c030d05231690.png

如果想要的组件没有提示,那么就只能在左边菜单中寻找,找到之后拖过来就行了。

这两个流程中的 UserTask 节点我也不做额外的设置,就设置一下每一个 UserTask 应该由谁来处理就可以了。假设第一个节点是组长来处理,第二个节点是经理处理,我们来看如何配置。

选中第一个 UserTask 之后,然后在下方找到分配用户,设置任务分配人:

856afdce54a4403cb4be6d2dcdd3ffbd.png

另外我这里啰嗦一句,每一个组件都需要设置组件的主键 ID(下方的第一个属性),当然也可以不设置,不设置这里会自动生成一个随机字符串,当然随机生成的可读性肯定是不如自己设置的可读性好了。

大家看到有四种不同的用户选项,我这里选择候选组,也就是将来由指定的用户组中的用户来处理这一个任务:

fb45722319ebf4e80e8898ee4ffa8064.png

选择完成之后,点击保存按钮:

e8ffb99765e82ba492f021b8e0058e3e.png利用相同的方式,给第二个 UserTask 也设置由经理进行处理。

好了,我们就绘制这样一个简单流程。

绘制完成后,点击左上角的勾进行检查,查看是流程图绘制是否正确,有的时候流程节点之间的连线起点和终点可能并没有放入正确的位置,肉眼不容易看到,点击左上角的勾可以帮我们检查一下


b2fdb00b25ccdedde17ed64d90691135.png

a0f81cb6c26883349c2ea2d8ed1a57f1.png

验证完成没有问题,点击左上角的保存按钮对当前流程图进行保存。

保存完成后,就可以在流程首页看到我们刚刚绘制的流程图了:

889fe9970a184e17e494bdd4d4cd3af8.png

点击流程图就可以查看流程图的详情,点击右上角的下载按钮,就可以下载这个流程图对应的 XML 文件了,将 XML 文件拷贝到我们的项目中,就可以开始开发啦。

fc79b65d881e29763c67ebbea9a43be0.png

5.2 发布应用程序

当然,我们也可以直接现场测试我们刚刚绘制好的流程图。

点击上方的应用程序,点击右上方的创建应用程序:

ed718f555c074fb38b34f14e87106c96.png

配置应用程序的基本信息:

1e9a7abae53a8686b6dd6cc8e2e94fd6.png

点击编辑包含的模型,为当前应用程序添加一个流程图:

59fb8788c2970b5f3253a252011e1147.png

4b8131bdf446fd45631c51a1eb6abae9.png

完成后点击左上角的保存按钮。

保存之后,我们就可以看到刚刚定义好的应用程序了:

bcfc09de3fdfb7146d4e796c7a2e7ef9.png

点进到这个应用程序中,点击右上角的发布按钮,可以发布该应用程序。

c876a77176a4f5c23a2914aeee5f46b1.png

发布之后,我们就可以在任务应用程序中来玩这个程序了。

6. 任务(Task)

经过前面的步骤之后,现在我们重新回到主页面,就可以发现除了刚刚一开始默认的四个菜单之外,现在还额外多了一个,就是我们刚刚新建的应用程序:

de5928573bec1438bb5d1064586250c5.png

我们可以直接点击 my_first_app 进入到任务应用程序中,也可以先进入到任务应用程序中,然后选择 my_first_app,都行。我以后者为例和大家演示一下吧:

首先进来之后,默认情况下是没有要执行的任务:

dfdd55bc01c1c798617b585edcc98583.png

点击到流程中,如下:

2784feb1a0909ac94a70168c24200616.png

默认情况下,也是没有正在执行的流程,我们现在可以点击启动流程按钮,来启动一个新的流程:

d0fcc028c1b4e7c4391eb0918458caa2.png

点击启动流程按钮之后,左边会展示出来所有的流程实例,我们现在只有一个发布的流程,所以选中该流程,点击右边的启动流程按钮:

26b65136ec9890385d4ae2f5cc2834a9.png

启动流程之后,点击显示图,可以查看流程走到哪一步了:

774b1b6a1a55b1ee157bd3e72a1d1ec2.png

点击活动任务,查看自己需要完成的任务。点击之后发现并没有需要完成的任务:bbf6b350170bc275190a925bceaa9d38.png

这是因为当前用户是 admin,而我们流程中第一个 UserTask 应该是由组长来处理的,所以我们现在注销登录,先以 zhangsan 的身份登录,因为 zhangsan 的角色是经理,所以他登录上来应该也是没有任务的:


91f464eb55398a5f57592177e2dd76e7.png

注意在筛选条件中选择我是其中一个候选人的任务(还是没有):

7f71c747810a620e65b25b2fd186a29c.png

再以 lisi 的身份登录,lisi 是组长,如下(也记得修改一下筛选条件):

9345d79530f09c5c22fb44d409cdc989.png

先点击认领按钮,认领该任务,然后点击完成按钮,完成自己的审批:

1881f9ff912ede8dc86f33febcbd7f91.png

完成之后,然后点击到流程中,然后点击左上角的显示图,如下:

9c9f224fc7dd18e2a88edd651beeeea8.png

cd39f3b4da0da5fada3cdc81b71389c0.png

此时可以看到,流程已经向后走了一步了。

接下来该经理审批了。

我们注销登录,再以 zhangsan 的身份登录,然后重复 lisi 的步骤,就可以完成这个流程了。

最终执行结果如下图:

9243d034495d747c0902f6389cbcde5b.png

流程执行完毕。

如果流程中涉及到排他性网关,似乎里无法测试,如果有小伙伴知道这里如何测试带有排他性网关的流程,欢迎留言告知。

7. 小结

今天的图有点多,希望小伙伴们对 flowable-ui 这个工具有一个基本的认知,好啦,有问题欢迎留言讨论。

相关文章
|
算法 前端开发 JavaScript
【五子棋实战】第1章 项目架构与开发思路
五子棋是一种古老而受欢迎的棋类游戏,本博客将介绍如何使用前端和算法接口来制作一个五子棋游戏。 此次实战项目包含项目的所有代码、教学的系列博客,分别放在公众号、CSDN,以便广大读者能够更好地学习、实践与二开。
292 0
|
3月前
|
前端开发 Java
表白墙/留言墙 —— 初级SpringBoot项目,练手项目前后端开发(带完整源码) 全方位全步骤手把手教学
文章通过一个表白墙/留言墙的初级SpringBoot项目实例,详细讲解了如何进行前后端开发,包括定义前后端交互接口、创建SpringBoot项目、编写前端页面、后端代码逻辑及实体类封装的全过程。
108 3
表白墙/留言墙 —— 初级SpringBoot项目,练手项目前后端开发(带完整源码) 全方位全步骤手把手教学
|
5月前
|
Java Maven Android开发
解锁Web开发新技能:从零开始的Struts 2之旅——让你的Java编程之路更加宽广,首个应用实例带你飞!
【8月更文挑战第31天】对于初学者,掌握 Struts 2 框架不仅能提升 Web 开发能力,还能深入了解 MVC 架构。Struts 2 是一个基于 Servlet 的 Java 框架,提供表单验证、文件上传、国际化等功能,便于快速构建易维护的 Web 应用。本文通过示例演示如何从零开始搭建环境并创建一个简单的 Struts 2 项目,包括配置 `struts.xml`、编写 Action 类及视图文件,并配置 web.xml。通过这些步骤,你将学会基本的开发流程,为进一步学习高级功能打下基础。
71 0
|
7月前
|
XML 缓存 Java
大厂面试攻略:Spring框架核心要点精讲
Java SPI (Service Provider Interface) 是一种服务发现机制,允许在运行时动态加载和发现服务提供者。在数据库驱动加载中,SPI使得数据库驱动能够自动识别和注册,而无需显式加载。 Spring 是一个广泛应用的轻量级框架,核心功能包括依赖注入(DI)和面向切面编程(AOP)。不使用Spring时,开发人员需要手动管理对象的创建和依赖关系,使用Servlet等基础组件完成Web开发,以及手动处理JDBC操作。Spring通过管理Bean的生命周期和依赖关系,简化了企业级应用的开发,降低了代码的侵入性。
89 1
大厂面试攻略:Spring框架核心要点精讲
|
7月前
|
消息中间件 缓存 中间件
【赠书活动 - 第1期】- 测试工程师Python开发实战(异步图书出品)| 文末送书
【赠书活动 - 第1期】- 测试工程师Python开发实战(异步图书出品)| 文末送书
|
7月前
技术经验分享:GMU简单使用一
技术经验分享:GMU简单使用一
96 0
|
敏捷开发 架构师 Java
GitHub上线重量级分布式架构原理设计笔记,开源的东西看着就是爽
在分布式系统中,一次业务处理可能需要多个应用来实现,比如用户发送一次下单请求,就涉及到订单系统创建订单,库存系统减库存,而对于一次下单,订单创建与减库存应该是要同时成功或者同时失效,但在分布式系统中,如果不做处理,就很有可能订单创建成功,但是减库存失败,那么解决这类问题,就需要用到分布式事务……
|
前端开发 Java 关系型数据库
IT市场寒冬过了!GitHub置顶的Spring微服务架构实战派手册有用了
“今年找工作好难啊” 感觉大家总是陷入市场寒冬这个氛围里面“无法自拔”,虽然今年经济下行,工作的确难找,但是在职友集上可查询到的Java岗位仍有20w+,需求相比其他而言并不算少,更别提还有技术细分下的岗位可选!
|
设计模式 前端开发 JavaScript
前端Web开发学习,入门到进阶,推荐几本很不错的书籍
前端Web开发学习,入门到进阶,推荐几本很不错的书籍
174 0
|
开发框架 Java Spring
高光时刻!美团推出Spring源码进阶宝典:脑图+视频+文档
Spring是一个开源框架,相信很多做Java开发的技术人员对Spring并不陌生,Spring是现在企业中经常会用到的,是为了解决企业应用程序开发复杂性而创建的。Spring主要的优势就是可以分层架构,可以为你提供选择使用哪一个组件,同时也会为J2EE应用程序开发体提供集成的框架!
79 0

热门文章

最新文章