工作流系统集成表单的过程,其实就是一个调用流程引擎api函数的集成过程。
工作流引擎只负责抽象的流程的流转,业务模块的实现,是在业务表单中完成。在和工作流系统集成的时候,完成表单提交的同时,再调用流程引擎的api执行流程的流转。
通常一套业务系统中,业务模块的实现,体现在一套MVC的框架中,无论是struts,spring,jsf等等都是为实现分层管理的mvc的框架。
一个业务功能的实现,在m,v,c这三个层面都有体现,好的mvc框架,能通过简单的配置来达到新增模块,只需要实现v展现层,m层的和数据库的交互。且需要维护的地方很少,集成度越高的框架越接近于自定义表单引擎,类似半自动化的表单系统。
无论用那种mvc的框架,在集成工作流系统的时候,流程只负责业务的流转,业务千变万化,业务模块的实现还是不可避免的要自己实现。
当工作流系统集成自定义的表单系统时,自定义表单引擎也会包含一种mvc框架,达到自己的定制实现。只是有了表单引擎+表单设计器,能更快捷方便的实现业务模块。
应用自定义表单时,会有很多的优势,只需要通过可视化的编辑设置,就能完成业务模块的实现,达到人机交互。当然也无需重新编译打包,无需发布,就能直接运行了。和工作流引擎的集成也已经做好,只需要通过可视化的功能调用,就能完成了和工作流系统的集成。这些集成的代码已经封装好了,用户只需可视化的设置。无需了解引擎的api功能。
工作流系统结合自定义表单系统,可以开放给终端的用户去做可视化的设计流程,定义表单,完成新增业务流程的功能。
当流程引擎集成第三方的jsp表单时,程序员就需要调用流程引擎的api来完成流程的流转功能。
流程引擎对外提供一系列的api,可以读出流程定义文档的整个定义串,得到任意节点信息。通过节点id也能获得节点定义类对象。
下面是eworkflow工作流系统在集成jsp表单时的调用过程。
为了方便表述,没有使用框架来实现业务模块的提交,只在jsp页面中嵌入java的代码来说明如何调用流程引擎的api。
页面表单中增加隐藏域,保存流程相关的参数。
<form id="frm" method="POST" action="leave_new_submit.jsp" onsubmit="return checkInput()">
<input type="hidden" name="wfName" value="<%=wfName%>">
<input type="hidden" name="wfVersion" value="<%=wfVersion%>">
<input type="hidden" name="wfId" value="<%=wfId%>">
<input type="hidden" name="actionId" value="<%=actionId%>">
<input type="hidden" name="leaveId" value="<%=leaveId%>">
.........
流程名称,版本,流程实例id,动作id,业务表主键id
在表单提交的时候
//获得流程参数
String wfName = request.getParameter("wfName");
String wfVersion = request.getParameter("wfVersion");
String wfId = request.getParameter("wfId");
String actionId = request.getParameter("actionId");
String dynamicId = request.getParameter("dynamicInstanceId");
//获得业务参数
String leaveType = request.getParameter("leaveType");
String leaveDays = request.getParameter("leaveDays");
String startDate = request.getParameter("startDate");
String endDate = request.getParameter("endDate");
String applyDate = request.getParameter("applyDate");
String remark = request.getParameter("remark");
然后,再先做业务记录的提交。
//先做业务记录的保存
StringBuffer sql = new StringBuffer();
sql.append("insert into ex_leave_apply");
sql.append(" (LEAVE_ID");
sql.append(" ,START_DATE");
sql.append(" ,REMARK");
sql.append(" ,END_DATE");
sql.append(" ,LEAVE_DAYS");
sql.append(" ,APPLY_DATE");
sql.append(" ,LEAVE_TYPE");
sql.append(" ,APPLY_USER");
sql.append(" ,WF_ID )");
sql.append(" values ( '" + IDUtils.getEformRecNumNo(env.getCon(),"BBB") + "'");
sql.append(",'" + startDate + "'");
sql.append(",'" + remark + "'");
sql.append(",'" + endDate + "'");
sql.append("," + leaveDays);
sql.append(",'" + applyDate + "'");
sql.append(",'" + leaveType + "'");
sql.append(",'" + userid + "'");
sql.append("," + wfId );
sql.append(")");
DBUtils.go(env.getCon(),sql.toString());
再启动流程引擎
执行流程的api,达到流程的流转
Workflow wf = new BasicWorkflow(userid,env);
wf.doAction(Long.parseLong(wfId), Integer.parseInt(actionId), inputs);
这样,就完成了一个流程节点的办理,既提交了业务数据,又执行了流程的流转。
在流程设计器中,节点上挂接jsp表单:
在流程实例运行时,执行到此节点,既打开挂接的jsp表单。
点击提交后,执行上面的代码过程,达到业务记录的提交,又调用流程引擎的api达到流程的流转。