浅析LR.Net工作流引擎
在当代信息化软件系统开发中,工作流引擎是其中非常重要的一环。所谓工作流引擎,是指工作流作为软件系统的一部分,
其中包括了流程的节点管理、流向管理、流程样例管理、审核管理等重要功能。
工作流引擎可根据角色、分工和条件的不同来决定信息传递的路由与内容的分级。其对各应用系统是有着决定作用的。
美观友好的交互界面,稳定的数据库信息交换,满足实际业务需求的高效程序逻辑,这些都是判断一个软件系统是否优
秀的重要标准。一个满足以上条件的系统,将会在一定程度上保证其稳定性和易用性。
做到程序稳定,是为了保证该系统的可靠性,满足界面易用,则是在保证模块化、结构化、操作的便捷性。这样可以在业
务流程发生变化,例如决策权的改变、组织结构的变动时,随之变换的全新业务逻辑,而工作流引擎解决的就是这个问题。
如果应用程序缺乏稳定高效的逻辑层,就会很容易出现包括信息路由错误、异常循环在内的各种错误。
这里举个简单的例子。一台电脑,外观前卫炫酷,但如果硬件系统有问题,那势必会出现各种BUG,如不加以改进,极有可
能被人嫌弃,最终变成一堆废品。而应用系统的拓展性就好比电脑的运行速度,别人开机只需五秒,而你的则需要五分钟
(业务流程变动需要更长时间的程序修改),孰优孰劣,一目了然。而如果电脑动不动就蓝屏重启(程序逻辑异常循环),
那这样的电脑谁还会用呢?
服务架构
面向服务的体系结构,是一个组件模型,它将应用程序的不同功能单元通过这些服务之间定义好的接口和契约联系起来。接
口是采用中立的方式进行定义的,它独立于硬件平台、操作系统和编程语言。工作流引擎使构建在各种系统中的服务,以统
一和通用的方式进行交互。
想要一套有灵活工作流机制的OA系统的企业不在少数,于是有很多人使用用Domino来摸索着做。等待后来ASP.NET出现,好像
大家都醒悟了,各领域企业都要求使用工作流引擎实现企业信息审批流程化。
基于企业的实际需求,近几年出现了一批标准的企业级工作流引擎,并获得了双软认证。这里讲一下口碑比较好的力软,总体
采用拖拽式设计,配合代码生成器,通用业务流程代码量接近于零,各项指标及客户反映都不错,其基本思路如下:
首先,定义流程步,主要包括:操作的接口地址、操作参数、操作类型(起始操作、中间操作等)。其目的是将来对每个操作进
行关系设置和流程定义时,可以选用这些定义好的操作步。
第二,定义操作的参数,除接口地址外,还需定义其参数。
第三,定义操作步之间的关系。就是定义各流程中每步的前驱、后继的操作。
第四,定义流程。其中必要的内容,是基本信息、流程操作以及流转规则。流程基本信息这里不表。流程步定义比较复杂,包括
步骤类型(起始、中间、终结),入口步骤、出口步骤、通知模式、人员、角色、发送通知的内容。
第五,跳步定义,如需根据参数的不同,提交审批到不同的步骤,这里叫做流程步骤变迁规则设置。设置的内容需要:原步骤、目
标步骤、变迁方向(正/负)、条件规则(判断参数时用与还是用或)。然后设置参数、参数值以及比较条件。
第六,授权管理。这个比较简单了,判断被提交的人是否处于授权状态,从而进行授权处理。
以上所说只是基础逻辑,实际编写过程中还要考虑各企业的实际情况,力软框架内置的工作流引擎,集合了各行业客户意见与建
议,适用性强,稳定性高,使用便捷,欢迎体验指正。
浅析LR.Net工作流引擎的更多相关文章
- 用Crontab打造简易工作流引擎
1. 引言 众所周知,Oozie(1, 2)是基于时间条件与数据生成来做工作流调度的,但是Oozie的数据触发条件只支持HDFS路径,故而面临着这样的问题: 无法判断Hive partition是否已 ...
- 工作流引擎Oozie(一):workflow
1. Oozie简介 Yahoo开发工作流引擎Oozie(驭象者),用于管理Hadoop任务(支持MapReduce.Spark.Pig.Hive),把这些任务以DAG(有向无环图)方式串接起来.Oo ...
- 【2016-11-7】【坚持学习】【Day22】【工作流引擎设计--执行用户】
最近在做一个工作流引擎,架构师已经设计好了,但是我发现他设计 每一步的用户集合的设计,有一定的不足,或者是不方便,不同的组织架构影响着他的用户数据源配置方式. 于是我想花点时间去看看人家优秀是工作流引 ...
- .net之工作流工程展示及代码分享(二)工作流引擎
在介绍完表单类的时候,接下来介绍工作流引擎,主要由四个类组成,分别是流程.流程步骤.流程实例.流程步骤实例类. 流程类: [Serializable] public class Flow { [Xml ...
- F2工作流引擎之-纯JS Web在线可拖拽的流程设计器(八)
Web纯JS流程设计器无需编程,完全是通过鼠标拖.拉.拽的方式来完成,支持串行.并行.分支.异或分支.M取N路分支.会签.聚合.多重聚合.退回.传阅.转交,都可以非常方便快捷地实现,管理员 ...
- F2.Net工作流引擎系列索引
索引如下 F2工作流引擎遵循参考WFCM标准规范,符合中国国情特色,更轻量级的工作流引擎,支持多种数据库(mmsqlserver,mysql,oracle),有强大智能的组织模型接口可快速应用到任何基 ...
- F2工作流引擎这工作流引擎体系架构(二)
F2工作流体系架构概览图 为了能更好的了解F2工作流引擎的架构体系,花了些时间画了整个架构的体系图.F2工作流引擎遵循参考WFCM规范,目标是实现轻量级的工作流引擎,支持多种数据库及快速应用到任何基于 ...
- F2工作流引擎Web层全新扁平化UI上线
特点:引入Bootstrap开源UI样式和fontawesome图标集 扁平化样式使用界面更舒服,按钮主题可快速定义更换,对于集成到业主系统UI图标更加丰富. 以下截取部分图片展示,更多请联系作者登录 ...
- F2工作流引擎之组织用户模型(四)
1 概述 工作流组织模型是工作流引擎中核心重要的一部份,是实现人机交互中不可或缺的组成部分,而由于工作流引擎需要适应不同的系统之间存在组织用户结构的不同, 如组织表中字段名不同,所以需要实现适应不同系 ...
随机推荐
- beyond compare4 密钥 亲测可用
beyond compare4过了试用期: 密钥: w4G-in5u3SH75RoB3VZIX8htiZgw4ELilwvPcHAIQWfwfXv5n0IHDp5hv1BM3+H1XygMtiE0-J ...
- iptables看门狗
近来业内很多服务器因redis造成服务器被黑,这个攻击的防范重点在于防火墙!! 有时为了方便我们可能会将iptables临时关闭,方便完倘若忘记把它打开,黑客大摇大摆就走进来. 这时候,我们需要条看门 ...
- 【av68676164(p55-p58)】 Intel CPU和Linux内存管理
7.4.1 Intel CPU物理结构 https://www.cnblogs.com/megachen/p/9768115.html x86实模式 实模式 20位:1M内存空间 地址表示方式:段地址 ...
- C# Thread.Join的报错情形——论执行完的线程能够成功执行Join吗
结论: 能, 执行完的线程调用Join不会抛出错误. Thread.Join()是什么? Join()函数用于阻塞地等待线程结束, 其行为是在线程A中调用了线程B的Join()后, 线程A将一直阻塞在 ...
- java 异常二
一 捕获异常try…catch…finally 捕获:Java中对异常有针对性的语句进行捕获,可以对出现的异常进行指定方式的处理 捕获异常格式: try { //需要被检测的语句. } catch(异 ...
- 2020-06-18:ZK的分布式锁怎么实现?
福哥答案2020-06-18: Zk分布式锁有两种实现方式一种比较简单,应对并发量不是很大的情况.获得锁:创建一个临时节点,比如/lock,如果成功获得锁,如果失败没获得锁,返回false释放锁:删除 ...
- C#LeetCode刷题-二分查找
二分查找篇 # 题名 刷题 通过率 难度 4 两个排序数组的中位数 C#LeetCode刷题之#4-两个排序数组的中位数(Median of Two Sorted Arrays)-该题未达最优解 30 ...
- C#LeetCode刷题之#605-种花问题( Can Place Flowers)
问题 该文章的最新版本已迁移至个人博客[比特飞],单击链接 https://www.byteflying.com/archives/3724 访问. 假设你有一个很长的花坛,一部分地块种植了花,另一部 ...
- Qt 信号发射部分 undefined reference to错误
在使用信号与槽很容易发生 undefined reference to 发射信号 ①继承QObject ②添加Q_OBJECT ③执行qmake ④构建 然后就可以运行啦!但是不知道是为什么,悄咪咪 ...
- ElasticSearch 7.8.1集群搭建
通往集群的大门 集群由什么用? 高可用 高可用(High Availability)是分布式系统架构设计中必须考虑的因素之一,它通常是指,通过设计减少系统不能提供服务的时间.如果系统每运行100个时间 ...