流程定义
WikeFlow2.0演示地址:http://workflow2.wikesoft.com
流程定义的作用
定义一个流程,并指定该流程的唯一Key值 。通过流程定义的Key值 ,在创建实例的时候,通过指定Key值 ,能找到创建的是什么流程。如何创建流程,请查看《如何创建流程》
工作流在执行的过程中,会通过反射的方式实例化业务类指定的对象,并调用IWorkFlowService接口实现的方法。
业务类名必须要有一个无参数的构造方法,如果业务类名没有无参数构造方法会导致调用不成功的异常。
如果你的业务类名的构造方法带有参数又不想调整,可以新建一个cs文件,这个类实现IWorkFlowService接口。
业务类的构造方法是一个无参数的构造方法。
流程定义字段解释:
1、定义Key:创建流程实例时指定的关键字。
2、业务路径:跟流程不相关的人,查看流程明细时绑定的页面路径,它是WorkFlowInstance/WorkFlowDetail.cshtml(.aspx)绑定的页面。
业务路径跟流程节点【待办路径】和【已办路径】的区别
待办路径:是审批人在【待办事项】审批时,查看流程明细时绑定的页面路径,是WorkFlowInstance/Exec.cshtml(.aspx)绑定的页面;
已办路径:是审批人在【已办事项】审批后,查看流程明细时绑定的页面路径,是WorkFlowInstance/Execed.cshtml(.aspx)绑定的页面。
3、业务程序集:业务类所在的程序集。
4、业务类名:相关业务的类名(命名空间.类名,该类要实现IWorkFlowService)
流程在执行过程中会通过反射的方式调用业务类实现的IWorkFlowService方法。
如何关联你的业务
流程定义要指定业务程序集和业务类名(命名空间.类名,该类要实现IWorkFlowService)。
该业务类要实现两部分功能
1、该业务类自己本身的业务功能(增、删、改、查或其它业务操作);
2、IWorkFlowService的六个接口的实现,这六个接口可以完成业务系统和工作流的交互功能。
当流程执行相关操作的时候,流程引擎自动调用业务类实现的IWorkFlowService方法,达到你的业务代码与WikeFlow2的系统交互功能。IWorkFlowService接口说明,请查看《关于IWorkFlowService》
演示用例的请假申请的业务程序集是WikeSoft.Enterprise,业务类名是WikeSoft.Enterprise.AppServices.HolidayApplyService
请假申请业务类HolidayApplyService代码截图如下图:
示例:HolidayService实现IWorkFlowServer的BeforeExecNextEvent接口
代码解释:
1、当申请人提交,将状态修改为审核中
2、驳回到申请人,将状态修改为未审核
3、流程结束,将状态修改为已审核
4、动作标记(ActionSign):是执行该动作的一个标记,通过该标记,你的业务系统能知道流程执行的什么操作,你的业务系统要处理什么逻辑。
/// <summary> /// 流程节点审批前事件 /// </summary> /// <param name="invokeMember">参数</param> /// <returns>WorkFlowMessage,如果Code= Fail,会中断流程引擎</returns> public WorkFlowMessage BeforeExecNextEvent(InvokeMember invokeMember) { WorkFlowMessage workFlowMessage = new InstanceMessage(); try { using (var context = new WikeDbContext()) { var data = context.Holidays.FirstOrDefault(c => c.INSTANCEID == invokeMember.InstanceId); if (data != null) { if (invokeMember.ActionSign == "start") { data.AUDITSTATE = "审核中"; } if (invokeMember.ActionSign == "reject_to_start") { data.AUDITSTATE = "未审核"; } if (invokeMember.ActionSign == "finish") { data.AUDITSTATE = "已审核 "; } context.Holidays.AddOrUpdate(data); context.SaveChanges(); } } } catch (Exception ex) { workFlowMessage.Code = CodeEum.Fail; workFlowMessage.Message = ex.Message; } return workFlowMessage; }
版权所有:本文档的任何部分,包括文字、图片、图形等均归属于成都惟科软件有限公司(以下简称“惟科软件”)。未经书面许可,任何单位或个人不得以任何方式摘录、复制、翻译、修改本手册的全部或部分。除非另有约定,惟科软件不对本手册提供任何明示或默示的声明或保证。
责任声明:在法律允许的最大范围内,本文档是“按照现状”提供,可能存在瑕疵或错误。惟科软件不对本文档提供任何形式的明示或默示保证,包括但不限于适销性、质量满意度、适合特定目的;亦不对使用或是分发本文档导致的任何特殊、附带、偶然或间接的损害进行赔偿,包括但不限于商业利润损失、系统故障、数据或文档丢失产生的损失。