Spring整合Activiti Modeler项目,支持浏览器编辑流程

1.官方下载Activiti 源代码: https://github.com/Activiti/Activiti ,云盘下载:http://pan.baidu.com/s/1pLUhNq7,如下:

2.下载Activiti 5.22.0:http://pan.baidu.com/s/1pLUhNq7。官网下载地址:https://www.activiti.org/ 

1、解压Activiti-master.zip,找到modules\activiti-webapp-explorer2\src\main\webapp下的diagram-viewer、editor-app、modeler.html,将其加到bamboo-activiti项目的webapp中。(这一步主要是Activiti Modeler的前段页面)

2、解压activiti-5.22.0.zip,找到wars在的activiti-explorer.war,将其放在tomcat的webapps下,启动tomcat将其解压,找activiti-explorer\WEB-INF\lib,拷贝所有jar包到bamboo-activiti的lib下。

3、给Activiti Modeler做配置文件applicationActiviti.xml:在并bamboo-activiti项目中添加名为,applicationActiviti.xml的配置文件,并在applicationContext.xml中引入import,

在Activiti-master中找到stencilset.json文件加到bamboo-activiti项目的配置文件里面。

applicationActiviti.xml的主要配置如下:

  1. <!-- 扫描activiti在线编辑器的跳转@RestController -->  
  2. <context:component-scan base-package="com.rest.editor" use-default-filters="false">  
  3.     <context:include-filter type="annotation" expression="org.springframework.stereotype.Controller">  
  4. </context:include-filter></context:component-scan>  

4、在Activiti 5.22.0的libs中找到activiti-modeler-5.22.0-sources.jar,将其解压,可以看到如下:

 , 

在bamboo-activiti项目中创建包名为:com.rest.editor,将上图3个类加到其中,如下图示:

回看第3步applicationActiviti.xml配置所指向的路径就是这3个类,这3个类就是Activiti Modeler的后台配置类。

5、在editor-app中找到app-cfg.js文件,将'contextRoot' : '/activiti-explorer/service',修改为本项目的路径。如下:

6,编写Activiti Modeler 页面跳转代码,如下:

  1. /** 
  2.     * 创建模型 
  3.     */  
  4.    @RequestMapping("create")  
  5.    public void create(HttpServletRequest request, HttpServletResponse response) {  
  6.        try {  
  7.         ProcessEngine processEngine = ProcessEngines.getDefaultProcessEngine();  
  8.            
  9.         RepositoryService repositoryService = processEngine.getRepositoryService();  
  10.            
  11.            ObjectMapper objectMapper = new ObjectMapper();  
  12.            ObjectNode editorNode = objectMapper.createObjectNode();  
  13.            editorNode.put("id", "canvas");  
  14.            editorNode.put("resourceId", "canvas");  
  15.            ObjectNode stencilSetNode = objectMapper.createObjectNode();  
  16.            stencilSetNode.put("namespace", "http://b3mn.org/stencilset/bpmn2.0#");  
  17.            editorNode.put("stencilset", stencilSetNode);  
  18.            Model modelData = repositoryService.newModel();  
  19.   
  20.            ObjectNode modelObjectNode = objectMapper.createObjectNode();  
  21.            modelObjectNode.put(ModelDataJsonConstants.MODEL_NAME, "hello1111");  
  22.            modelObjectNode.put(ModelDataJsonConstants.MODEL_REVISION, 1);  
  23.            String description = "hello1111";  
  24.            modelObjectNode.put(ModelDataJsonConstants.MODEL_DESCRIPTION, description);  
  25.            modelData.setMetaInfo(modelObjectNode.toString());  
  26.            modelData.setName("hello1111");  
  27.            modelData.setKey("12313123");  
  28.   
  29.            //保存模型  
  30.            repositoryService.saveModel(modelData);  
  31.            repositoryService.addModelEditorSource(modelData.getId(), editorNode.toString().getBytes("utf-8"));  
  32.            response.sendRedirect(request.getContextPath() + "/modeler.html?modelId=" + modelData.getId());  
  33.        } catch (Exception e) {  
  34.            System.out.println("创建模型失败:");  
  35.        }  
  36.    }  

7,修改index.jsp,添加链接

<a href="user/create">activiti-modele-index</a>

注意:右键属性,将下图:

8、别忘了Activiti 5.22.0数据库,在Activiti 5.22.0.zip中。

 

三、整合项目bamboo-activiti

浏览器访问:http://localhost:8080/activiti/

首页

activiti-modele

 

1)整合完整版下载:http://pan.baidu.com/s/1pLUhNq7

转载于:https://my.oschina.net/heguojun/blog/1576031

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值