百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 编程网 > 正文

深入浅出,工作流引擎 进行深入浅出的解读

yuyutoo 2024-11-11 16:48 6 浏览 0 评论

随着 LCDP(低代码开发平台) 不断被公众认知,规模也在日益扩大,正在不断地惊醒着每个开发者,变革才是出路。由此我们简单带出我们今天要谈的WorkFlow工作流引擎。

WorkFlow工作流引擎目前是以BPMN和Active工作流为两大阵营为主,源代码以:Java、net为主,而PHP几乎没有工作流引擎(这就很尴尬了)。

说完大体情况,我们开始进入正文:

什么是工作流引擎(Workflow Engine )

开发一个系统,最关键的部分不是系统的界面,也不是和数据库之间的信息交换,而是如何根据业务逻辑开发出符合实际需要的程序逻辑并确保其稳定性、易维护性(模块化和结构化)和弹性(容易根据实际业务逻辑的变化作出程序上的变动,例如决策权的改变、组织结构的变动和由于业务方向的变化产生的全新业务逻辑等等)。 Workflow 引擎解决的就是这个问题:如果应用程序缺乏强大的逻辑层,势必变得容易出错。

就好比一辆汽车,外表做得再漂亮,如果发动机有问题就只是一个摆设。应用系统的弹性就好比引擎转速方面的性能,加速到100 公里需要1 个小时(业务流程发生变动需要进行半年的程序修改)还能叫好车吗?引擎动不动就熄火(程序因为逻辑的问题陷入死循环)的车还敢开吗?(来源于百度百科)

为什么要用工作流引擎?

为了解释这个问题,我们来举个例子:
应用场景: 张三工程师正在研发一套OA、ERP等企业信息管理平台
客户需求: 有个物资系统,客户希望这么做,A填写申请表——B部门经理审核——C物资管理部确认——D张三领用物资
张三工程师: 立刻开始了业务需求调研,分析,总结。然后开始写代码了。业务表单很简单(这里我们就忽略了)
审批设计:-1 退回修改 0 保存编辑 1部门经理审核 2 物资部门确认 is_use 是否领用
根据设计:写了如下代码:

public function check(){
    $code = input('code');
    $userId = session('uid');
   switch ($code){
        case 1: //B核准
       //一大堆逻辑代码
        break;
        case 2: //c物资部核准`
         //一大堆逻辑代码
        break;
        default: //张三发起申请
         //一大堆逻辑代码
        } 
   }
}

这时候,张三工程师,很快写完了代码。逻辑也正确,权限判断完全没问题,很高兴的跟客户开始了一系列的骚操作,并审核通过。
时间过了半个月,软件还在运维应用期间。客户给张三工程师打电话,我们领导说,要增加一个审核功能,

改为:A填写申请表——B部门经理审核——E主任核实——C物资管理部确认——D张三领用物资

问题来了: 而这个客户系统,有数十条,类似的审核业务?如果都这样变动?

这时候,求张三工程师的心里阴影面积?

总结下: 从上面的例子来说,不能说张三工程师的代码逻辑有问题,业务逻辑有问题。但是问题在哪里?

我个人认为,在于没有很好处理业务与逻辑之间的关键因素。我们常说,信息管理系统业务是一半,工作流程是一半。如何整合好这两个关系。需要应用到工作流引擎。

废话太多,来点实际~

用工作流解决上面张三工程师的问题

李四接手了,张三的业务,全面分析了,下系统。决定开发个专门管理该公司的业务流程问题。 把业务与流程剥离。

通过可视化快速构建。在2分钟就完成了上面的逻辑架构,同样的,改造了数十条业务逻辑。而这些,他只用了不到1个小时。


张三工程师,不可思议的说,原来还有工作流这东西~~~

总结来了

通过上面的小Demo应该很容易看出工作流强大的优势在于哪里。

不管你业务怎么变化,流程怎么变化,都能通过可视化的拖拽设计,

把专业的流程驱动交给专业的流程引擎,归集与统一。

你省去的不仅仅是流程的调研,客户需求分析时间,

更是你写if else 一大堆重复代码的时间。


最后回到原题:

深入浅出,工作流引擎。LCDP(低代码开发平台)的出现并非偶然,而是在发展过程中的必然,专业化的表单设计,流程驱动,会打破传统开发的弊端,为企业在快速构建,数据驱动上提供先进的技术生产力!

最后推荐几个国产流程引擎:

PHP流程引擎TPflow https://gitee.com/ntdgg/tpflow PHP优秀的工作流新秀

JAVA流程引擎Jflow:https://gitee.com/opencc/JFlow 坚持流程开发12年

相关推荐

史上最全的浏览器兼容性问题和解决方案

微信ID:WEB_wysj(点击关注)◎◎◎◎◎◎◎◎◎一┳═┻︻▄(页底留言开放,欢迎来吐槽)●●●...

平面设计基础知识_平面设计基础知识实验收获与总结
平面设计基础知识_平面设计基础知识实验收获与总结

CSS构造颜色,背景与图像1.使用span更好的控制文本中局部区域的文本:文本;2.使用display属性提供区块转变:display:inline(是内联的...

2025-02-21 16:01 yuyutoo

写作排版简单三步就行-工具篇_作文排版模板

和我们工作中日常word排版内部交流不同,这篇教程介绍的写作排版主要是用于“微信公众号、头条号”网络展示。写作展现的是我的思考,排版是让写作在网格上更好地展现。在写作上花费时间是有累积复利优势的,在排...

写一个2048的游戏_2048小游戏功能实现

1.创建HTML文件1.打开一个文本编辑器,例如Notepad++、SublimeText、VisualStudioCode等。2.将以下HTML代码复制并粘贴到文本编辑器中:html...

今天你穿“短袖”了吗?青岛最高23℃!接下来几天气温更刺激……

  最近的天气暖和得让很多小伙伴们喊“热”!!!  昨天的气温到底升得有多高呢?你家有没有榜上有名?...

CSS不规则卡片,纯CSS制作优惠券样式,CSS实现锯齿样式

之前也有写过CSS优惠券样式《CSS3径向渐变实现优惠券波浪造型》,这次再来温习一遍,并且将更为详细的讲解,从布局到具体样式说明,最后定义CSS变量,自定义主题颜色。布局...

柠檬科技肖勃飞:大数据风控助力信用社会建设

...

你的自我界限够强大吗?_你的自我界限够强大吗英文

我的结果:A、该设立新的界限...

行内元素与块级元素,以及区别_行内元素和块级元素有什么区别?

行内元素与块级元素首先,CSS规范规定,每个元素都有display属性,确定该元素的类型,每个元素都有默认的display值,分别为块级(block)、行内(inline)。块级元素:(以下列举比较常...

让“成都速度”跑得潇潇洒洒,地上地下共享轨交繁华
让“成都速度”跑得潇潇洒洒,地上地下共享轨交繁华

去年的两会期间,习近平总书记在参加人大会议四川代表团审议时,对治蜀兴川提出了明确要求,指明了前行方向,并带来了“祝四川人民的生活越来越安逸”的美好祝福。又是一年...

2025-02-21 16:00 yuyutoo

今年国家综合性消防救援队伍计划招录消防员15000名

记者24日从应急管理部获悉,国家综合性消防救援队伍2023年消防员招录工作已正式启动。今年共计划招录消防员15000名,其中高校应届毕业生5000名、退役士兵5000名、社会青年5000名。本次招录的...

一起盘点最新 Chrome v133 的5大主流特性 ?

1.CSS的高级attr()方法CSSattr()函数是CSSLevel5中用于检索DOM元素的属性值并将其用于CSS属性值,类似于var()函数替换自定义属性值的方式。...

竞走团体世锦赛5月太仓举行 世界冠军杨家玉担任形象大使

style="text-align:center;"data-mce-style="text-align:...

学物理能做什么?_学物理能做什么 卢昌海

作者:曹则贤中国科学院物理研究所原标题:《物理学:ASourceofPowerforMan》在2006年中央电视台《对话》栏目的某期节目中,主持人问过我一个的问题:“学物理的人,如果日后不...

你不知道的关于这只眯眼兔的6个小秘密
你不知道的关于这只眯眼兔的6个小秘密

在你们忙着给熊本君做表情包的时候,要知道,最先在网络上引起轰动的可是这只脸上只有两条缝的兔子——兔斯基。今年,它更是迎来了自己的10岁生日。①关于德艺双馨“老艺...

2025-02-21 16:00 yuyutoo

取消回复欢迎 发表评论: