java 实现一套流程管理、流转的思路(伪工作流)
在做某个管理项目时,被要求实现一套流程管理,比如请假的申请审批流程等,在参考了很多资料,并和同事讨论后,得到了一个自主实现的流程管理。
以下提供我的设计思路,知道了思路,实现起来就简单很多了。
首先我设计了5个类来实现流程的自主设置,主要是对流程的定义和流程流转。
注:这是设计的图,并不是实现
Dictionary:数据字典,不多说,流程类型存在这里面
Flow:流程,即流程的定义,其中包括流程名称,描述,类型,启用时间,备注等;目前是通过判断某个类别的流程启用时间来进行判断当前流程是否启用的。
一个类别只启用一个流程。所以只需要通过流程类别即可确定流程,并不要特定的状态字段。
FlowInfoMovingNode:流程节点,在分析流程流转的时候,我们发现,流转一步就相当于从一个节点跳到另一个节点,所以我们设计这个流程节点类来表示每一步。
其中包括,所属流程,节点名称,节点描述,监听权限。
解释下监听权限是什么. 由于我们做的大部分是审核的流程,所以每个节点都需要有个审核的过程才进入下一个节点,所以我们要这个handlerRole属性来确定这个节点究竟是什么权限来审核。我们也知道,审核一般是某个人审核,这个我们后面说。这里是规定某个权限,即可以审核这个节点的权限。
FlowInfoMovingRole:流程流转规则,为了解决从节点出来的各个分支,我们设计了这个流转规则,本来其实可以一起放到FlowInfoMovingNode中,但这样话无论从数据上 还是管理上来说都不如加流转规则方便清楚。FlowInfoMovingRole主要用来确定流转规则,比如某个节点通过了应该去哪个节点,某个节点没通过应该去哪个节点,这样无论是分支还是单支还是循环都可以通过相同的方式来进行设置。transition为变换规则,参照shiro验证权限的方式,我们也使用纯字符串格式来进行判断变换规则。
FlowInfoMoving:流程流转信息,这里是每一步流转信息的存放,基本在进行流程流转的过程中,都是通过此类,其中包括:所属节点(得到所属节点同时也就得到所属流 程),申请源(因为我们不知道申请源是什么,我们只是管流程是怎么运转的,其申请源跟我们没有任何关系,我们保存申请源的唯一标识,若是想在审核的过程中进行查看申请源信息,则可以请求在Flow中监听的Url(handlerUrl),来进行查看,我会把申请源的唯一标识当做参数传递到Url中)。
由于这个是操作最频繁的,所以我来具体解释下这个类。
以下为本人具体实现的类设计,属性字段均有注释进行解释:
/**
* 流程流转信息
* @author lichao *
*/
@Entity
@Table(name = FlowInfoMoving.TABLE_NAME)
public class FlowInfoMoving extends BaseAuditEntity { private static final long serialVersionUID = 1L; public static final String TABLE_NAME = "t_flowInfoMoving"; // 流程节点,标识此流转信息是流转到了哪个节点
@ManyToOne(fetch = FetchType.EAGER)
@JoinColumn(name = "node_id",nullable = true)
private FlowInfoMovingNode node; // 申请源,具体申请信息的唯一标识
@Column
private Long applyId; // 申请人,具体申请信息的申请人
@ManyToOne(fetch = FetchType.EAGER)
@JoinColumn(name = "applyuser_id",nullable = false)
private User applyUser; // 申请信息,具体申请信息的简要概述,由申请提供
@Column(length = 50)
@Size(max = 50)
private String discription; // 申请类别,即申请的流程的类型
@ManyToOne(fetch = FetchType.EAGER)
@JoinColumn(name = "flowtype_id",nullable = false)
private Dictionary applyType; // 变换的结果,即审核通过未通过等条件,此条件同FlowInfoMovingRole种的transition,
// 但有一些区别,因为有添加待审核,已结束等其他信息条件
@Column(length = 50)
@Size(max = 50)
private String transition; // 处理信息,即审核信息,由审核人添加
@Column(length = 100)
@Size(max = 100)
private String handlerInfo; // 处理人,即此流转应该由谁来申请,由FlowInfoMovingNode中的handlerRole来进行筛选,
//并由上一个节点的处理人来进行选择具体审核人。
@ManyToOne(fetch = FetchType.EAGER)
@JoinColumn(name = "handleruser_id",nullable = false)
private User handlerUser; // 此流转信息的状态,用于查询,0未审核,1已审核,2本申请已经结束
@Column()
private int status; //getter...and setter.... }
FlowInfoMoving
这样整个流程定义就结束了,我们可以自由设置流程的流程规则,来设置流程的流转方式。这样无论任何复杂的流程都可以进行自定义,并且可以随意的修改。
这样设计的结果首先是可以任意的自定义流程,其次是申请源不需要去管流程的流转了,只需要提交一份申请,其他的事情均由流程进行操作实现。
那么我们来看看一个流程是如何进行运转的。
1.首先通过一个接口来传递具体的一些申请信息。
2.通过接口中的getType()来确定是哪个流程
3.查询到开始的流程节点。
4.将开始的信息保存到流转信息中,并等待处理
5.由审核人处理,指定下一个审核人
6.通过处理结果来获得下一个流程节点
7.查找下一个节点
8.将这次的处理信息和下一个节点的信息保存到流转信息中,并等待处理
9.由审核人处理,这样一直循环知道流程结束
10.通过审核信息查找的下一个节点为null,则表示此流程已经结束,
11.将结束的信息保存到流程流转信息中
12.将整个流程流转的状态改为已结束。
首先是Applyable是怎么设计的:其实一个接口,用于提供一些申请的信息
public interface Applyable { // 得到申请的id,与类别进行联合查询,用于确定具体是哪个流程
Long getId(); // 得到申请的类别,用于确定具体是哪类流程
String getApplyType(); // 得到变换条件,用于确定申请后的第一个步骤
String getTransition(); // 得到此次申请的描述
String getDiscription(); // 得到审批人,即第一个步骤由谁审批
User getHandlerUser(); }
Applyable
然后是主要的控制流程流转和申请的接口
/**
*
*@Description:处理流程业务的Service
*@Author:lichao
*@Since:Oct 10, 201412:02:39 PM
*/
public interface FlowMainService { /**
*
*@Description: 用于申请
*@Author: lichao
*@Since: Oct 10, 20143:19:07 PM
*@param applyable
*@return
* @throws Exception
*/
public void applyFlow(Applyable applyable) throws Exception; /**
*
*@Description: 查找当前所处的流转信息
*@Author: medees
*@Since: Oct 13, 20148:56:00 AM
*@param applyid 申请源
*@param applytype 申请类别
*@return
*/
public FlowInfoMoving findNowMoving(Long applyid,Dictionary applyType); /**
*
*@Description: 查找某一流程下的所有走过的流程 按创建时间升序排序
*@Author: lichao
*@Since: Oct 13, 20141:46:54 PM
*@param applyid 申请源
*@param applytype 申请类别
*@return
*/
public List<FlowInfoMoving> findAllMoving(Long applyid,Dictionary applyType); /**
*
*@Description: 获取所有变换条件
*@Author: lichao
*@Since: Oct 13, 20144:27:41 PM
*@param nodeid 所处节点的id
*@return
*/
public List<String> findNextTransition(Long nodeid); /**
*
*@Description: 得到此节点可以审核的所有用户
*@Author: lichao
*@Since: Oct 14, 201410:22:50 AM
*@param nodeid 节点id
*@param applyid 申请源
*@param applyUserId 申请人id
*@return
*/
public List<User> findNextAppUser(Long nodeid,String transition,Long applyUserId); /**
*
*@Description: 分页查询自己所审批的流程
*@Author: lichao
*@Since: Oct 14, 20141:39:50 PM
*@return
*/
public Page<FlowInfoMoving> findMyMoving(Pageable pageRequest); /**
*
*@Description: 进行审核的方法
*@Author: lichao
*@Since: Oct 15, 20142:11:18 PM
*@param moving
* @throws Exception 如果审核出错则抛出异常
*/
public boolean approval(FlowInfoMoving moving) throws Exception; /**
*
*@Description: 查找一个流程的所有流转
*@Author: lichao
*@Since: Oct 16, 201411:04:03 AM
*@param applyid
*@param applytype
*@return
*/
public Page<FlowInfoMoving> findAllMoving(Long applyid,Long applytype,Pageable Pageable); /**
*
*@Description: 重新申请
*@Author: lichao
*@Since: Oct 17, 20141:43:03 PM
*@return
*/
public void resetApply(Applyable applyable) throws Exception; /**
*
*@Description: 是否需要重新申请
*@Author: lichao
*@Since: Oct 17, 20141:43:03 PM
*@return
*/
public boolean isNeedReset(Long applyid,Dictionary dic); }
FlowMainService
申请源只要调用此接口中的applyFlow进行申请即可。
具体实现就不在提供了!
以上!
)
java 实现一套流程管理、流转的思路(伪工作流)的更多相关文章
- java 实现一套流程管理、流转的思路(伪工作流) 【仅供参考】
转: java 实现一套流程管理.流转的思路(伪工作流) 在做某个管理项目时,被要求实现一套流程管理,比如请假的申请审批流程等,在参考了很多资料,并和同事讨论后,得到了一个自主实现的流程管理. 以下提 ...
- 熊乐:H3 BPM为加速企业流程管理提供源动力
近日,在北京·金隅喜来登酒店,H3 BPM以"让天下没有难用的流程"为主题,正式发布H3 BPM10.0版本.全新的业务流程管理系统在易用性方面大大提升,并且全面支持Java与.N ...
- JAVA实现用户的权限管理
一:写在前面 前两天有个同学问我,那个系统不同的用户登陆不同的页面不同,要写很多个页面啊!而每个用户的在系统中拥有不同的权限,可以访问不同的页面是怎么实现的??那低权限的在浏览器输入高权限的人的url ...
- Java EE开发课外事务管理平台
Java EE开发课外事务管理平台 演示地址:https://ganquanzhong.top/edu 说明文档 一.系统需求 目前课外兴趣培训学校众多,完善,但是针对课外兴趣培训学校教务和人事管理信 ...
- 制造行业流程管理的“IPO”思维
流程管理是企业从流程角度出发,关注流程是否增值的一套管理体系.从认识流程.到建立流程.到管理流程.再到优化流程,企业管理人员要去除不增值和低价值的流程,减少员工犯错误的机会,建立一套卓越的流程体系. ...
- 基于 Java Web 的毕业设计选题管理平台--选题报告与需求规格说明书
一.选题报告 目录 团队名称 团队成员 项目名称 项目描述 创新与收益 用户场景分析 真实用户调研 未来市场与竞争 项目导图 比例权重 总结 1.团队名称--指南者团队 2.团队成员 孔潭活:2015 ...
- Xianfeng轻量级Java中间件平台:权限管理
权限管理:是通过系统对用户的行为进行控制的一套业务规则,可以做得很简单,比如通过硬编码的方式进行控制,也可以做得很复杂,比如通过一些复杂的权限模型去实现一些复杂的权限控制,比如菜单访问权限.按钮操作权 ...
- jbpm(流程管理)
1.jbpm是什么 JBPM,全称是Java Business Process Management(业务流程管理),它是覆盖了业务流程管理.工作流.服务协作等领域的一个开源的.灵活的.易扩展的可执行 ...
- 流程管理软件(BPM)功能简介
易协流程管理系统实现将人为控制的业务活动,通过信息化手段实现系统控制,降低人为控制管理的风险以及促进企业的各项决策方针的顺利实施. 系统目标: 实现管理的规范化.制度化.程序化: 帮助企业将内控制度流 ...
随机推荐
- Android-Activity横竖屏切换不杀死Activity 并监听横竖屏切换
在上一篇博客,Android-Activity临时数据的保存,中讲解到,当发生横竖屏切换的时候,系统会杀死Activity并重新启动Activity 系统会杀死Activity 12-12 08:11 ...
- [LeetCode 题解]:Best Time to Buy and Sell Stock
前言 [LeetCode 题解]系列传送门: http://www.cnblogs.com/double-win/category/573499.html 1.题目描述 Say you ha ...
- ZT 基于git的版本管理思路
http://nvie.com/posts/a-successful-git-branching-model/ 分为5种分支: feature:功能分支,开发人员在此种分支下开发新的功能,开发完成后m ...
- 腾讯云通信UserSig生成.Net实现
腾讯云通信后台生成usersig只有java实现代码.以下是根据java代码转换为net实现,java版GitHub地址:https://github.com/TencentVideoCloudMLV ...
- MVC断点续传
using System;using System.Collections.Generic;using System.Linq;using System.Web;using System.Web.Mv ...
- 在线绘图网站 UML、思维导图、 流程图、 用例图等等
https://www.processon.com/ 用我的微信登录即可 帐号是 QQ邮箱
- 936. Stamping The Sequence
You want to form a target string of lowercase letters. At the beginning, your sequence is target.len ...
- 关键字的使用 pass break continue
# ### 关键字的使用 # (1)pass 过 作用 作站位用的 if 5==5: pass i = 0 while i <5: pass #约定俗成,在循环里面什么也不行的情况下,给友好提示 ...
- PHP中SimpleXMLElement对象字符编码
最近在使用SimpleXMLElement来生成和解析XML. 由于我们使用PHP开发的这边使用UTF-8编码,而对方使用GBK编码,因此就遇到了中文字符编码问题. 后来发现,XML内部的编码与其头 ...
- Linux/Windows 平台最容易安装 Composer教程
我们采用的是全局安装方式,这样的话,就能够在命令行窗口中直接执行 composer 命令了. Mac 或 Linux 系统: 打开命令行窗口并执行如下命令将前面下载的 composer.phar 文件 ...