我的框架是spring +spring data jpa+spring mvc+activiti5.16.2
activiti 的包我就不说了,不想找麻烦就都拿过来,我也没有做什么整理,拿过来用就行了,以后可以慢慢研究。
下面是配置文件,我假设你已经会使用activiti,怎么整合到spring应该没问题,在整合网页设计器时主要是配置web.xml文件:
<!-- Restlet adapter, used to expose modeler functionality through REST --> <servlet> <servlet-name>ExplorerRestletServlet</servlet-name> <servlet-class>org.restlet.ext.servlet.ServerServlet</servlet-class> <init-param> <!-- Application class name --> <param-name>org.restlet.application</param-name> <param-value>org.activiti.explorer.rest.application.ExplorerRestApplication</param-value> </init-param> </servlet> <servlet> <servlet-name>RestletServlet</servlet-name> <servlet-class>org.restlet.ext.servlet.ServerServlet</servlet-class> <init-param> <!-- Application class name --> <param-name>org.restlet.application</param-name> <param-value>org.activiti.rest.service.application.ActivitiRestServicesApplication</param-value> </init-param> </servlet> <!-- Catch all service requests --> <servlet-mapping> <servlet-name>ExplorerRestletServlet</servlet-name> <url-pattern>/service/*</url-pattern> </servlet-mapping> <servlet-mapping> <servlet-name>RestletServlet</servlet-name> <url-pattern>/rest/*</url-pattern> </servlet-mapping>
activiti的网页设计器是使用rest技术,所以web.xml文件里面需要配置一下rest。
接下来就是要引入网页了:
首先将activiti-explorer.war 包 解压开来。
需要的文件有:
将其拷贝到项目中
将其拷贝到:src/main/resource下面
如果你的不是这样的结构,你直接拷贝到src
最后还要整合一个java代码,也就是web.xml所引用的那个类:
package org.activiti.explorer.rest.application; import org.activiti.rest.common.api.DefaultResource; import org.activiti.rest.common.application.ActivitiRestApplication; import org.activiti.rest.common.filter.JsonpFilter; import org.activiti.rest.editor.application.ModelerServicesInit; import org.restlet.Restlet; import org.restlet.routing.Router; public class ExplorerRestApplication extends ActivitiRestApplication { public ExplorerRestApplication() { super(); } /** * Creates a root Restlet that will receive all incoming calls. */ @Override public synchronized Restlet createInboundRoot() { Router router = new Router(getContext()); router.attachDefault(DefaultResource.class); ModelerServicesInit.attachResources(router); JsonpFilter jsonpFilter = new JsonpFilter(getContext()); jsonpFilter.setNext(router); return jsonpFilter; } }
需要注意的是包路径要写对。
这样做药之后项目可以运行起来了,但是还没发看到网页设计器,还缺少一个管理页面,暂且叫它流程模型控制器,需要一个controller类和几个页面
package com.weir.oa.activiti.web.workflow; import java.io.ByteArrayInputStream; import java.util.List; import javax.servlet.http.HttpServletRequest; import javax.servlet.http.HttpServletResponse; import com.fasterxml.jackson.databind.JsonNode; import com.fasterxml.jackson.databind.ObjectMapper; import com.fasterxml.jackson.databind.node.ObjectNode; import com.weir.oa.util.DataGrid; import com.weir.oa.util.Json; import org.activiti.bpmn.converter.BpmnXMLConverter; import org.activiti.bpmn.model.BpmnModel; import org.activiti.editor.constants.ModelDataJsonConstants; import org.activiti.editor.language.json.converter.BpmnJsonConverter; import org.activiti.engine.RepositoryService; import org.activiti.engine.repository.Deployment; import org.activiti.engine.repository.Model; import org.apache.commons.io.IOUtils; import org.apache.commons.lang3.StringUtils; import org.slf4j.Logger; import org.slf4j.LoggerFactory; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.stereotype.Controller; import org.springframework.web.bind.annotation.PathVariable; import org.springframework.web.bind.annotation.RequestMapping; import org.springframework.web.bind.annotation.ResponseBody; /** * 流程模型控制器 * * @author henryyan */ @Controller @RequestMapping(value = "/model") public class ModelController { protected Logger logger = LoggerFactory.getLogger(getClass()); @Autowired RepositoryService repositoryService; /** * 模型列表 */ @ResponseBody @RequestMapping("list") public DataGrid<Model> list() { List<Model> list = repositoryService.createModelQuery().list(); DataGrid<Model> dg = new DataGrid<Model>((long)list.size(),list); return dg; } /** * 创建模型 */ @RequestMapping("create") public void create(String name,String key, String description, HttpServletRequest request, HttpServletResponse response) { try { ObjectMapper objectMapper = new ObjectMapper(); ObjectNode editorNode = objectMapper.createObjectNode(); editorNode.put("id", "canvas"); editorNode.put("resourceId", "canvas"); ObjectNode stencilSetNode = objectMapper.createObjectNode(); stencilSetNode.put("namespace", "http://b3mn.org/stencilset/bpmn2.0#"); editorNode.put("stencilset", stencilSetNode); Model modelData = repositoryService.newModel(); ObjectNode modelObjectNode = objectMapper.createObjectNode(); modelObjectNode.put(ModelDataJsonConstants.MODEL_NAME, name); modelObjectNode.put(ModelDataJsonConstants.MODEL_REVISION, 1); description = StringUtils.defaultString(description); modelObjectNode.put(ModelDataJsonConstants.MODEL_DESCRIPTION, description); modelData.setMetaInfo(modelObjectNode.toString()); modelData.setName(name); modelData.setKey(StringUtils.defaultString(key)); //保存模型 repositoryService.saveModel(modelData); repositoryService.addModelEditorSource(modelData.getId(), editorNode.toString().getBytes("utf-8")); response.sendRedirect(request.getContextPath() + "/service/editor?id=" + modelData.getId()); } catch (Exception e) { logger.error("创建模型失败:", e); } } /** * 根据Model部署流程 */ @ResponseBody @RequestMapping("deploy") public Json deploy(String modelId) { Json json = new Json(); try { Model modelData = repositoryService.getModel(modelId); ObjectNode modelNode = (ObjectNode) new ObjectMapper().readTree(repositoryService.getModelEditorSource(modelData.getId())); byte[] bpmnBytes = null; BpmnModel model = new BpmnJsonConverter().convertToBpmnModel(modelNode); bpmnBytes = new BpmnXMLConverter().convertToXML(model); String processName = modelData.getName() + ".bpmn20.xml"; Deployment deployment = repositoryService.createDeployment().name(modelData.getName()).addString(processName, new String(bpmnBytes)).deploy(); json.setMsg("部署成功,部署ID=" + deployment.getId()); json.setSuccess(true); } catch (Exception e) { logger.error("根据模型部署流程失败:modelId={}", modelId, e); json.setMsg("模型部署流程失败"); } return json; } /** * 导出model的xml文件 */ @RequestMapping("export") public void export(String modelId, HttpServletResponse response) { try { Model modelData = repositoryService.getModel(modelId); BpmnJsonConverter jsonConverter = new BpmnJsonConverter(); JsonNode editorNode = new ObjectMapper().readTree(repositoryService.getModelEditorSource(modelData.getId())); BpmnModel bpmnModel = jsonConverter.convertToBpmnModel(editorNode); BpmnXMLConverter xmlConverter = new BpmnXMLConverter(); byte[] bpmnBytes = xmlConverter.convertToXML(bpmnModel); ByteArrayInputStream in = new ByteArrayInputStream(bpmnBytes); IOUtils.copy(in, response.getOutputStream()); String filename = bpmnModel.getMainProcess().getId() + ".bpmn20.xml"; response.setHeader("Content-Disposition", "attachment; filename=" + filename); response.flushBuffer(); } catch (Exception e) { logger.error("导出model的xml文件失败:modelId={}", modelId, e); } } @RequestMapping(value = "delete/{modelId}") public String delete(@PathVariable("modelId") String modelId) { repositoryService.deleteModel(modelId); return "redirect:/workflow/model/list"; } }
网页(easyui实现):list 列表页面
<%@ page language="java" contentType="text/html; charset=UTF-8" pageEncoding="UTF-8"%> <!DOCTYPE html> <html> <head> <jsp:include page="/pub.jsp"></jsp:include> <title>流程列表</title> <script type="text/javascript"> var userDataGrid; $(function() { userDataGrid = $('#user_datagrid').datagrid({ url : '${pageContext.request.contextPath}/model/list.do', fit : true, fitColumns : true, border : false, pagination : true, idField : 'id', pagePosition : 'both', checkOnSelect:true, selectOnCheck:true, columns : [ [ { field : 'id', title : 'ID' }, { field : 'key', title : 'KEY', sortable : true }, { field : 'name', title : '名称', sortable : true }, { field : 'version', title : '版本' }, { field : 'createTime', title : '创建时间' }, { field : 'lastUpdateTime', title : '更新时间' }, { field : 'metaInfo', title : '元数据' }] ], toolbar : [ { text : '增加', iconCls : 'ext-icon-add', handler : function() { userAdd(); } }], onRowContextMenu:function(e, rowIndex, rowData){ e.preventDefault(); $(this).datagrid('unselectAll'); $(this).datagrid('selectRow',rowIndex); $('#user_menu').menu('show', { left : e.pageX, top : e.pageY }); } }); $('#user_edit_depid').combotree({ url : '${pageContext.request.contextPath}/dep/tree.do', idField:'departmentId', textField:'departmentname', parentField : 'parentId', lines : true, panelHeight : 'auto', onClick: function(node){ $("#user_edit_depid").combotree('setValue', node.departmentId); } }); }); function userAdd() { fromReset("admin_addUserForm"); $('#admin_addUser').dialog('open'); } function addUserForm(){ $('#admin_addUserForm').submit(); } function userEdit(){ var rows = userDataGrid.datagrid('getChecked'); if(rows.length==1){ window.open("${pageContext.request.contextPath}/service/editor?id="+rows[0].id); }else{ parent.$.messager.alert('提示','请选择一条记录进行修改'); } } function exportModel(){ var rows = userDataGrid.datagrid('getChecked'); if(rows.length==1){ window.open("${pageContext.request.contextPath}/model/export.do?modelId="+rows[0].id); }else{ parent.$.messager.alert('提示','请选择一条记录进行修改'); } } function deployModel(){ var rows = userDataGrid.datagrid('getChecked'); if(rows.length==1){ $.post('${pageContext.request.contextPath}/model/deploy.do', {modelId:rows[0].id}, function(j) { parent.$.messager.progress({ title : '提示', text : '数据处理中,请稍后....' }); if (j.success) { parent.$.messager.progress('close'); userDataGrid.datagrid('load'); } userDataGrid.datagrid('uncheckAll'); $.messager.show({ title : '提示', msg : j.msg, timeout : 5000, showType : 'slide' }); }, 'json'); }else{ parent.$.messager.alert('提示','请选择一条记录进行修改'); } } function userDelete(){ var rows = userDataGrid.datagrid('getChecked'); var ids = []; if(rows.length>0){ $.messager.confirm('确认','您确认想要删除记录吗?',function(r){ if (r){ for(var i=0;i<rows.length;i++){ ids.push(rows[i].id); } $.post('${pageContext.request.contextPath}/user/delete.do', {ids:ids.join(',')}, function(j) { if (j.success) { userDataGrid.datagrid('load'); $('#admin_addUser').dialog('close'); } userDataGrid.datagrid('uncheckAll'); $.messager.show({ title : '提示', msg : j.msg, timeout : 5000, showType : 'slide' }); }, 'json'); } }); }else{ $.messager.show({ title : '提示', msg : '请勾选要删除的记录', timeout : 5000, showType : 'slide' }); } } </script> </head> <body> <div class="easyui-layout" data-options="fit:true,border:false"> <div data-options="region:'center',border:false,title:'模型列表'" style="overflow: hidden;"> <table id="user_datagrid"></table> </div> </div> <div id="user_menu" class="easyui-menu" style="width: 120px;display: none;"> <div onclick="userEdit()" iconCls="icon-edit">编辑</div> <div onclick="deployModel()" iconCls="icon-edit">部署</div> <div onclick="exportModel()" iconCls="icon-edit">导出</div> <div onclick="userDelete()" iconCls="icon-remove">删除</div> </div> <div id="admin_addUser" class="easyui-dialog" data-options="closed:true,modal:true,title:'添加用户',buttons:[{ text : '保存', iconCls : 'icon-save', handler : function() { addUserForm(); } }]" style="width: 300px;height: 200px;"> <form id="admin_addUserForm" action="${pageContext.request.contextPath}/model/create.do" target="_blank" method="post"> <table> <tr> <th>名称</th> <td><input name="name" id="name" class="easyui-validatebox" data-options="required:true,missingMessage:'名称必填'" /></td> </tr> <tr> <th>KEY</th> <td><input name="key" id="key" class="easyui-validatebox" data-options="required:true,missingMessage:'KEY必填'" /></td> </tr> <tr> <th>描述</th> <td><textarea id="description" name="description"></textarea></td> </tr> </table> </form> </div> </body> </html>
add 创建页面:
<%@ page language="java" pageEncoding="UTF-8"%> <!DOCTYPE html> <html> <head> <title>创建模型</title> <meta name="content-type" content="text/html; charset=UTF-8"> <jsp:include page="/pub.jsp"></jsp:include> <script type="text/javascript"> var useradd_submitForm = function(dialog, user_datagrid, p) { if ($('user_addForm').form('validate')) { /* $.post('${pageContext.request.contextPath}/model/create.do', $("#user_addForm").serialize(), function(j) { }, 'json'); */ var form = document.forms[0]; form.action='${pageContext.request.contextPath}/model/create.do'; form.submit(); } }; </script> </head> <body> <form id="user_addForm" action="" method="post"> <input type="hidden" name="userId"/> <table style="width: 100%;"> <tr> <th>名称</th> <td><input name="name" id="name" class="easyui-validatebox" data-options="required:true,missingMessage:'名称必填'" /></td> </tr> <tr> <th>KEY</th> <td><input name="key" id="key" class="easyui-validatebox" data-options="required:true,missingMessage:'KEY必填'" /></td> </tr> <tr> <th>描述</th> <td><textarea id="description" name="description"></textarea></td> </tr> </table> </form> </body> </html>
现在你就可以对模型通过activiti网页设计器进行增删改查,还有部署和导出操作了。
网页设计器的整合基本就需要这些,也不是特别麻烦。
补充:
package com.weirblog.util; import java.util.ArrayList; import java.util.List; public class DataGrid<T> { private Long total = 0L; private List<T> rows = new ArrayList<T>(); public DataGrid() { super(); } public DataGrid(Long total, List<T> rows) { super(); this.total = total; this.rows = rows; } public Long getTotal() { return total; } public void setTotal(Long total) { this.total = total; } public List<T> getRows() { return rows; } public void setRows(List<T> rows) { this.rows = rows; } }
作者博客:http://www.loveweir.com
相关推荐
Activiti工作流引擎是一款强大的开源工作流解决方案,它基于模型驱动的架构,旨在为企业...而提供的"Activiti整合流程设计器"压缩包文件很可能包含了示例代码、配置文件和教程资源,有助于进一步学习和实践这个主题。
《Activiti 5.22 Web 流程设计器整合实战详解》 在信息化管理中,流程自动化扮演着至关重要的角色,而Activiti作为一款开源的工作流引擎,深受开发者喜爱。本示例“activiti5.22-web流程设计器整合demo”提供了一个...
`stencilset.json` 文件是Activiti流程设计器的核心配置,它定义了流程图中可用的各种形状(如开始事件、结束事件、用户任务等)以及它们的属性和行为。开发者可以通过修改这个JSON文件来定制自己的流程元素库,以...
忙活了一个星期左右,查找各种资料,终于将Activiti的流程设计器分离出来,与SpringMVC,spring整合了起来,先把工程分享出来,等有时间了在慢慢讲解具体的整合步骤。工程下载之后直接可以运行,只需要改一下数据库...
Activiti-Modeler是一款强大的工作流网页版设计器,专为简化和优化业务流程管理而设计。它基于流行的Activiti工作流引擎,提供了一个直观、易用的界面,使得开发者和业务分析师无需深入代码就能设计、修改和部署工作...
在本文中,我们将深入探讨如何将Spring Boot 2与Activiti 5流程设计器进行整合,以便在Java开发环境中实现高效的工作流管理。首先,我们需要理解这两个核心组件:Spring Boot和Activiti。 Spring Boot是Spring框架...
终于将Activiti的流程设计器分离出来,与SpringMVC,spring整合了起来,先把工程分享出来,等有时间了在慢慢讲解具体的整合步骤。工程下载之后直接可以运行,只需要改一下数据库连接。访问...
Activiti Modeler 是Activiti提供的一个流程设计器,允许用户通过Web界面创建、编辑和管理流程模型,无需编写代码,极大地提升了流程设计的效率和可维护性。 Oracle是世界上最广泛使用的数据库系统之一,尤其在企业...
SpringBoot 2.1.1 整合 Activiti 5.22 Web 流程设计器是将企业级工作流引擎Activiti与流行的轻量级Java开发框架Spring Boot结合的实践。这一整合使得开发者能够轻松地在Web环境中设计、运行和管理业务流程。以下是...
Activiti Designer则是与Activiti引擎配套的一款基于Eclipse的图形化流程设计工具,它允许开发者通过拖拽方式构建复杂的业务流程模型。 在深入探讨Activiti Designer之前,我们先了解一下BPMN 2.0。Business ...
这个压缩包“activiti5.19整合(包含设计器)”提供了 Activiti 5.19 版本与Spring 4 和 ExtJS 4.2.3 的集成示例,其中包含了流程设计器和流程管理模块,旨在帮助开发者更好地理解和应用 Activiti 在实际项目中的工作...
《Activiti整合流程自定义设计:SpringBoot+Activiti+Bootstrap+Angular实战解析》 在当今的信息化时代,业务流程管理(BPM)系统已成为企业不可或缺的一部分。Activiti,一个强大的开源工作流引擎,以其易用性和...
小编 做的这个项目有部分功能用到了 Activiti工作流,目前对工作流的掌握程度是基本会用,我之前写过一篇 Activiti 入门篇,当前这篇文章是属于Activiti 实战部分,如果你想知道Activiti 工作流是如何使用的话,那就...
### 整合activiti-5.21.0流程设计器 #### 一、整合activiti-5.21.0流程设计器 为了提高流程设计的便捷性和效率,本篇文章将介绍如何整合activiti-modeler 5.21.0版,并对其进行二次封装,从而降低开发难度。下面将...
代码为activiti 流程设计器示例,另: jeecg + activiti 流程设计器整合 链接:https://blog.csdn.net/anysun7/article/details/79970420
Activiti的流程设计器分离出来,与SpringMVC,spring整合了起来,先把工程分享出来,等有时间了在慢慢讲解具体的整合步骤。工程下载之后直接可以运行,只需要改一下数据库连接。访问...
特别的是,它还集成了网页设计器,让用户能够直观地设计和修改工作流,实现真正的"开箱即用"体验。 **SpringBoot 2.0.3** 是一个基于Spring框架的高度简化和自动配置的启动器,使得开发Spring应用程序变得更加便捷...
BPMN 无处不在,适合所有人 在浏览器中创建、嵌入和扩展 BPMN 图。单独使用它或将其集成到您的应用...3. 集成浏览器内流程引擎、令牌模拟、自定义元素、样式或建模规则。这取决于您,因为 bpmn-js 是一个开放的工具包。
综上所述,"activiti整合drools案例"是一个将业务流程管理与规则引擎相结合的实际应用,通过这种方式,我们可以构建出更加智能、适应性强的企业业务系统。学习并掌握这一整合技术,对于提升企业业务系统的灵活性和...
它提供了一套图形化的流程设计工具,可以方便地创建和修改流程定义。ACTIVITI5不仅支持基本的流程控制,还具备复杂的决策和事件处理能力。通过与SPRING的集成,ACTIVITI5可以轻松地嵌入到现有的Spring应用中,实现...