modeler与activiti进行整合

简介:

整合Activiti Modeler到业务系统(或BPM平台) 
http://www.kafeitu.me/activiti/2013/03/10/integrate-activiti-modeler.html 

activit 5.12.1集成activiti-modeler 到 自己的业务系统(集成流程跟踪-完美支持IE)http://jhaij.iteye.com/blog/1871635 
根据第二篇文章,整合成功; 

FAQ: 
1. 无法进入editor. 
http://localhost:8080/YouPRJ/modeler/service/editor?id=2050,前提是这个id必需存在与act_re_model表里面, 
那么,在调用这个之前,如何插入一条记录到这个表么? 
待解决........ 
------------- 
看到咖啡兔的例子,是先使用java保存到数据库,然后再打开editor, 保存的代码: 
javascript: 一边保存,一边打开,同时保存后的页面又做reload, 很特别很有趣的做法,值得学习.... 

Js代码   收藏代码
  1. $(function() {  
  2.         $('#create').button({  
  3.             icons: {  
  4.                 primary: 'ui-icon-plus'  
  5.             }  
  6.         }).click(function() {  
  7.             $('#createModelTemplate').dialog({  
  8.                 modal: true,  
  9.                 width: 500,  
  10.                 buttons: [{  
  11.                     text: '创建',  
  12.                     click: function() {  
  13.                         if (!$('#name').val()) {  
  14.                             alert('请填写名称!');  
  15.                             $('#name').focus();  
  16.                             return;  
  17.                         }  
  18.                         setTimeout(function() {  
  19.                             location.reload();  
  20.                         }, 1000);  
  21.                         $('#modelForm').submit();  
  22.                     }  
  23.                 }]  
  24.             });  
  25.         });  
  26.     });  

 

Java代码   收藏代码
  1. @RequestMapping(value = "create", method = RequestMethod.POST)  
  2.   public void create(@RequestParam("name") String name, @RequestParam("key") String key, @RequestParam("description") String description,  
  3.           HttpServletRequest request, HttpServletResponse response) {  
  4.     try {  
  5.       ObjectMapper objectMapper = new ObjectMapper();  
  6.       ObjectNode editorNode = objectMapper.createObjectNode();  
  7.       editorNode.put("id", "canvas");  
  8.       editorNode.put("resourceId", "canvas");  
  9.       ObjectNode stencilSetNode = objectMapper.createObjectNode();  
  10.       stencilSetNode.put("namespace", "http://b3mn.org/stencilset/bpmn2.0#");  
  11.       editorNode.put("stencilset", stencilSetNode);  
  12.       Model modelData = repositoryService.newModel();  
  13.   
  14.       ObjectNode modelObjectNode = objectMapper.createObjectNode();  
  15.       modelObjectNode.put(ModelDataJsonConstants.MODEL_NAME, name);  
  16.       modelObjectNode.put(ModelDataJsonConstants.MODEL_REVISION, 1);  
  17.       description = StringUtils.defaultString(description);  
  18.       modelObjectNode.put(ModelDataJsonConstants.MODEL_DESCRIPTION, description);  
  19.       modelData.setMetaInfo(modelObjectNode.toString());  
  20.       modelData.setName(name);  
  21.       modelData.setKey(StringUtils.defaultString(key));  
  22.   
  23.       repositoryService.saveModel(modelData);  
  24.       repositoryService.addModelEditorSource(modelData.getId(), editorNode.toString().getBytes("utf-8"));  
  25.   
  26.       response.sendRedirect(request.getContextPath() + "/service/editor?id=" + modelData.getId());  
  27.     } catch (Exception e) {  
  28.       logger.error("创建模型失败:", e);  
  29.     }  
  30.   }  



2. web editor保存的bpmn20文件到哪里去了? 
     会更新ACT_RE_MODEL和ACT_GE_BYTEARRAY表,ACT_GE_BYTEARRAY表保存了图片和xml文件信息(其实是json格式的字符串),并关联到ACT_RE_MODEL表。 
     ACT_RE_MODEL 
       说明:流程设计器设计流程后,保存数据到该表。 
                EDITOR_SOURCE_VALUE_ID(流程文件放在ACT_GE_BYTEARRAY中的ID); 
                EDITOR_SOURCE_EXTRA_VALUE_ID(流程文件图像放在ACT_GE_BYTEARRAY中的ID)。 

3. 如何去部署保存在数据库里面的ACT_RE_MODEL表里面的工作流? 
    咖啡兔的源码: 创建,部署,删除,导出,遍历 

Java代码   收藏代码
  1. package me.kafeitu.demo.activiti.web.workflow;  
  2.   
  3. import java.io.ByteArrayInputStream;  
  4. import java.util.List;  
  5.   
  6. import javax.servlet.http.HttpServletRequest;  
  7. import javax.servlet.http.HttpServletResponse;  
  8.   
  9. import org.activiti.bpmn.converter.BpmnXMLConverter;  
  10. import org.activiti.bpmn.model.BpmnModel;  
  11. import org.activiti.editor.constants.ModelDataJsonConstants;  
  12. import org.activiti.editor.language.json.converter.BpmnJsonConverter;  
  13. import org.activiti.engine.RepositoryService;  
  14. import org.activiti.engine.repository.Deployment;  
  15. import org.activiti.engine.repository.Model;  
  16. import org.apache.commons.io.IOUtils;  
  17. import org.apache.commons.lang3.StringUtils;  
  18. import org.codehaus.jackson.JsonNode;  
  19. import org.codehaus.jackson.map.ObjectMapper;  
  20. import org.codehaus.jackson.node.ObjectNode;  
  21. import org.slf4j.Logger;  
  22. import org.slf4j.LoggerFactory;  
  23. import org.springframework.beans.factory.annotation.Autowired;  
  24. import org.springframework.stereotype.Controller;  
  25. import org.springframework.web.bind.annotation.PathVariable;  
  26. import org.springframework.web.bind.annotation.RequestMapping;  
  27. import org.springframework.web.bind.annotation.RequestMethod;  
  28. import org.springframework.web.bind.annotation.RequestParam;  
  29. import org.springframework.web.servlet.ModelAndView;  
  30. import org.springframework.web.servlet.mvc.support.RedirectAttributes;  
  31.   
  32. /** 
  33.  * 流程模型控制器 
  34.  *  
  35.  * @author henryyan 
  36.  */  
  37. @Controller  
  38. @RequestMapping(value = "/workflow/model")  
  39. public class ModelController {  
  40.   
  41.   protected Logger logger = LoggerFactory.getLogger(getClass());  
  42.   
  43.   @Autowired  
  44.   RepositoryService repositoryService;  
  45.   
  46.   /** 
  47.    * 模型列表 
  48.    */  
  49.   @RequestMapping(value = "list")  
  50.   public ModelAndView modelList() {  
  51.     ModelAndView mav = new ModelAndView("workflow/model-list");  
  52.     List<Model> list = repositoryService.createModelQuery().list();  
  53.     mav.addObject("list", list);  
  54.     return mav;  
  55.   }  
  56.   
  57.   /** 
  58.    * 创建模型 
  59.    */  
  60.   @RequestMapping(value = "create", method = RequestMethod.POST)  
  61.   public void create(@RequestParam("name") String name, @RequestParam("key") String key, @RequestParam("description") String description,  
  62.           HttpServletRequest request, HttpServletResponse response) {  
  63.     try {  
  64.       ObjectMapper objectMapper = new ObjectMapper();  
  65.       ObjectNode editorNode = objectMapper.createObjectNode();  
  66.       editorNode.put("id", "canvas");  
  67.       editorNode.put("resourceId", "canvas");  
  68.       ObjectNode stencilSetNode = objectMapper.createObjectNode();  
  69.       stencilSetNode.put("namespace", "http://b3mn.org/stencilset/bpmn2.0#");  
  70.       editorNode.put("stencilset", stencilSetNode);  
  71.       Model modelData = repositoryService.newModel();  
  72.   
  73.       ObjectNode modelObjectNode = objectMapper.createObjectNode();  
  74.       modelObjectNode.put(ModelDataJsonConstants.MODEL_NAME, name);  
  75.       modelObjectNode.put(ModelDataJsonConstants.MODEL_REVISION, 1);  
  76.       description = StringUtils.defaultString(description);  
  77.       modelObjectNode.put(ModelDataJsonConstants.MODEL_DESCRIPTION, description);  
  78.       modelData.setMetaInfo(modelObjectNode.toString());  
  79.       modelData.setName(name);  
  80.       modelData.setKey(StringUtils.defaultString(key));  
  81.   
  82.       repositoryService.saveModel(modelData);  
  83.       repositoryService.addModelEditorSource(modelData.getId(), editorNode.toString().getBytes("utf-8"));  
  84.   
  85.       response.sendRedirect(request.getContextPath() + "/service/editor?id=" + modelData.getId());  
  86.     } catch (Exception e) {  
  87.       logger.error("创建模型失败:", e);  
  88.     }  
  89.   }  
  90.   
  91.   /** 
  92.    * 根据Model部署流程 
  93.    */  
  94.   @RequestMapping(value = "deploy/{modelId}")  
  95.   public String deploy(@PathVariable("modelId") String modelId, RedirectAttributes redirectAttributes) {  
  96.     try {  
  97.       Model modelData = repositoryService.getModel(modelId);  
  98.       ObjectNode modelNode = (ObjectNode) new ObjectMapper().readTree(repositoryService.getModelEditorSource(modelData.getId()));  
  99.       byte[] bpmnBytes = null;  
  100.   
  101.       BpmnModel model = new BpmnJsonConverter().convertToBpmnModel(modelNode);  
  102.       bpmnBytes = new BpmnXMLConverter().convertToXML(model);  
  103.   
  104.       String processName = modelData.getName() + ".bpmn20.xml";  
  105.       Deployment deployment = repositoryService.createDeployment().name(modelData.getName()).addString(processName, new String(bpmnBytes)).deploy();  
  106.       redirectAttributes.addFlashAttribute("message", "部署成功,部署ID=" + deployment.getId());  
  107.     } catch (Exception e) {  
  108.       logger.error("根据模型部署流程失败:modelId={}", modelId, e);  
  109.     }  
  110.     return "redirect:/workflow/model/list";  
  111.   }  
  112.   
  113.   /** 
  114.    * 导出model的xml文件 
  115.    */  
  116.   @RequestMapping(value = "export/{modelId}")  
  117.   public void export(@PathVariable("modelId") String modelId, HttpServletResponse response) {  
  118.     try {  
  119.       Model modelData = repositoryService.getModel(modelId);  
  120.       BpmnJsonConverter jsonConverter = new BpmnJsonConverter();  
  121.       JsonNode editorNode = new ObjectMapper().readTree(repositoryService.getModelEditorSource(modelData.getId()));  
  122.       BpmnModel bpmnModel = jsonConverter.convertToBpmnModel(editorNode);  
  123.       BpmnXMLConverter xmlConverter = new BpmnXMLConverter();  
  124.       byte[] bpmnBytes = xmlConverter.convertToXML(bpmnModel);  
  125.   
  126.       ByteArrayInputStream in = new ByteArrayInputStream(bpmnBytes);  
  127.       IOUtils.copy(in, response.getOutputStream());  
  128.       String filename = bpmnModel.getMainProcess().getId() + ".bpmn20.xml";  
  129.       response.setHeader("Content-Disposition", "attachment; filename=" + filename);  
  130.       response.flushBuffer();  
  131.     } catch (Exception e) {  
  132.       logger.error("导出model的xml文件失败:modelId={}", modelId, e);  
  133.     }  
  134.   }  
  135.   
  136.   @RequestMapping(value = "delete/{modelId}")  
  137.   public String delete(@PathVariable("modelId") String modelId) {  
  138.      repositoryService.deleteModel(modelId);  
  139.     return "redirect:/workflow/model/list";  
  140.   }  
  141.   
  142. }  





问题: 
1. java.lang.NoSuchMethodError: org.activiti.engine.impl.bpmn.diagram.ProcessDiagramCanvas.drawSequenceflowWithoutArrow(IIIIZZ)V 
应为本地有两个工程的pom.xml都使用了 

Xml代码   收藏代码
  1. <dependency>  
  2.     <groupId>org.activiti</groupId>  
  3.     <artifactId>activiti-engine</artifactId>  
  4.     <version>${activiti.version}</version>  
  5. </dependency>  

本文转自二郎三郎博客园博客,原文链接:http://www.cnblogs.com/haore147/p/5213210.html,如需转载请自行联系原作者
临时关闭或者删除一个工程,就不会提示这个错误了,至于为什么?我也搞不清楚。。。网上几乎没有人碰到这个错误,莫非是我太幸运???


相关文章
|
9月前
|
存储 数据采集 数据可视化
Pandas数据应用:电子商务数据分析
本文介绍如何使用 Pandas 进行电子商务数据分析,涵盖数据加载、清洗、预处理、分析与可视化。通过 `read_csv` 等函数加载数据,利用 `info()` 和 `describe()` 探索数据结构和统计信息。针对常见问题如缺失值、重复记录、异常值等,提供解决方案,如 `dropna()`、`drop_duplicates()` 和正则表达式处理。结合 Matplotlib 等库实现数据可视化,探讨内存不足和性能瓶颈的应对方法,并总结常见报错及解决策略,帮助提升电商企业的数据分析能力。
373 73
|
9月前
|
SQL DataWorks 搜索推荐
DataWorks产品评测与最佳实践体验报告
DataWorks是阿里巴巴云推出的一款高效数据处理平台,通过内置的数据集成工具和ETL功能,实现了多源数据的自动化处理与分析。本文介绍了DataWorks在用户画像分析中的应用实践,展示了其如何帮助企业高效管理数据资源,支持决策制定及营销优化。同时,文章还评测了DataWorks的产品体验,包括开通流程、功能满足度等方面,并与其它数据开发平台进行了比较,突出了DataWorks在易用性、性能和生态完整性上的优势。最后,对Data Studio新版本中的Notebook环境进行了初步探索,强调了其在提升开发效率方面的价值。
306 16
|
消息中间件 缓存 算法
社招一年半面经分享(含阿里美团头条京东滴滴)
重点放在专业技能和项目经验两块1.你的简历就是你给面试官提供的考点,简历上的东西必须自己Hold住,万一自己写的东西被问住了,会很尴尬,给面试官留下的印象也不好,所以就是会啥写啥2.技术栈最好不要写精通,你敢写面试官就敢问,被问倒了很尴尬的,写熟悉,了解就行怎么投简历我这里强烈建议找人内推,这样简历通过的概率大些,如果找不到,可以试试脉脉,我就是从脉脉投的简历,把状态改成寻找机会就行,会有很多人找你的推荐一个简历制作模版,我一直用的,https://www.polebrief.com/index算法这个该刷还是得刷,别偷懒,我个人感觉刷完下面几个已经够了,大家可以根据自己的基础情况选择剑指Of
1012 1
|
资源调度 运维 监控
如何通过任务调度实现百万规则报警
报警是一个公司的日常需求,常见的形态除了满足运维过程中的基础设施监控报警(CPU/内存/磁盘等)之外,部分公司也会在应用指标(如 QPS、RT 等)及业务指标(如 GMV/日活 等)上有相应的报警需求。
4335 90
如何通过任务调度实现百万规则报警
|
机器学习/深度学习 人工智能 自然语言处理
探索人工智能的未来:深度学习与神经网络的融合
在人工智能的广阔天地中,深度学习和神经网络如同两股激流,汇聚成推动技术进步的巨浪。本文将深入探讨这两种技术如何相辅相成,共同塑造未来人工智能的发展轨迹。我们将从基础概念出发,逐步揭示它们在实际应用中的协同效应,以及这种融合如何引领我们步入一个更加智能化的未来。
|
C# Windows
C#捕获windows关机事件,在系统关机前做一些自己想做的事
C#捕获windows关机事件,在系统关机前做一些自己想做的事; 有些时候我们可能想在Windows关机时记录或处理一些事情,这里提供几种方法。 方法一: /// /// 窗口过程的回调函数 /// /// ...
1944 0
|
运维 安全 持续交付
亿氪虹云携手蝶宇云为金蝶云·星空用户带来「IaaS+运维+安全」的三位一体的整体解决方案
为了给用户带来更佳的运维服务,蝶宇云不断进行服务优化,在确定了要从传统的运维服务商向云的应用服务商转型的方向后,与亿氪虹云展开了深度合作。由亿氪虹云在阿里云云市场上来提供金蝶云·星空的计算巢SaaS服务,服务基于阿里云计算巢功能,在交付上实现了自动化部署;在数据安全方面提供了操作录屏功能,可以随时回放审计,为用户数据安全保驾护航;另外用户还可以根据业务实际情况进行非常灵活地扩容,及扩展和伸缩。给金蝶云·星空企业用户带来「IaaS+运维+安全」的三位一体的整体解决方案。
314 0
|
Web App开发 iOS开发
为 iPhone 和 iPad 自定义网站的主屏幕图标
iPhone 和 iPad 等苹果设备使用主屏幕 (Home Screen, 也称桌面) 管理应用程序, 还可以通过浏览器的添加到主屏幕功能将网站链接作为快捷方式添加为主屏幕图标. 是否你也想过为网站定义一个图标, 如果用户将网站添加至主屏幕, 网站链接看起来更像原生程序, 也能获得更多的关注.
1697 0
|
Prometheus 资源调度 监控
Prometheus PushGateway 碎碎念
Prometheus 是一套开源的监控告警系统,PushGateway 是其中一个组件。这个组件用来收取推送来的数据并且供 Prometheus 来拉取。
494 0
官宣!支付宝小程序的 23 个入口大盘点
近日,支付宝小程序场景值文档发布。场景值用于描述用户进入小程序的路径,也就是说,场景值即代表了的小程序入口 。
3806 12
官宣!支付宝小程序的 23 个入口大盘点