activiti5 开发

大家在开发过程,可以参考很多网上的案例,说到集成开发,其实可以直接参考activiti提供给我们的activiti-rest-5.18.0,这个jar本来是提供rest接口,大家在开发过程如果想使用什么api其实可以直接参考这个jar的源码,基本都提供了,很方便也不用去看什么代码。

在集成的时候,可能需要activiti-diagram-rest-5.18.0 这个jar是给js生成流程图的接口,大家如果没有使用diagram-viewer这个做流程图,可以不需要引入。

还有在集成modeler的时候activiti-modeler-5.18.0只要这个jar即可,这个jar提供了modeler的保存和查询接口。

顺便说一下,5.18版本的modeler支持了ie8但是在保存的时候可能会出现错误。

跟踪接口发现是在activiti-modeler-5.18.0的jar中保存接口出错,其实是在保存svg_xml解析生成图片的时候犹豫ie8生成的xml字符串不对出错。其实这里可以不需要svg_xml生成图片注释掉,而且这里使用了batik-codec-1.7生成图片,其实可以不需要。

/* Licensed under the Apache License, Version 2.0 (the "License");
 * you may not use this file except in compliance with the License.
 * You may obtain a copy of the License at
 * 
 *      http://www.apache.org/licenses/LICENSE-2.0
 * 
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 */
package org.activiti.rest.editor.model;

import java.io.ByteArrayInputStream;
import java.io.ByteArrayOutputStream;
import java.io.InputStream;

import org.activiti.editor.constants.ModelDataJsonConstants;
import org.activiti.engine.ActivitiException;
import org.activiti.engine.RepositoryService;
import org.activiti.engine.repository.Model;
import org.apache.batik.transcoder.TranscoderInput;
import org.apache.batik.transcoder.TranscoderOutput;
import org.apache.batik.transcoder.image.PNGTranscoder;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.http.HttpStatus;
import org.springframework.util.MultiValueMap;
import org.springframework.web.bind.annotation.PathVariable;
import org.springframework.web.bind.annotation.RequestBody;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestMethod;
import org.springframework.web.bind.annotation.ResponseStatus;
import org.springframework.web.bind.annotation.RestController;

import com.fasterxml.jackson.databind.ObjectMapper;
import com.fasterxml.jackson.databind.node.ObjectNode;

/**
 * @author Tijs Rademakers
 */
@RestController
public class ModelSaveRestResource implements ModelDataJsonConstants {
  
  protected static final Logger LOGGER = LoggerFactory.getLogger(ModelSaveRestResource.class);

  @Autowired
  private RepositoryService repositoryService;
  
  @Autowired
  private ObjectMapper objectMapper;
  
  @RequestMapping(value="/model/{modelId}/save", method = RequestMethod.PUT)
  @ResponseStatus(value = HttpStatus.OK)
  public void saveModel(@PathVariable String modelId, @RequestBody MultiValueMap<String, String> values) {
    try {
      
      Model model = repositoryService.getModel(modelId);
      
      ObjectNode modelJson = (ObjectNode) objectMapper.readTree(model.getMetaInfo());
      
      modelJson.put(MODEL_NAME, values.getFirst("name"));
      modelJson.put(MODEL_DESCRIPTION, values.getFirst("description"));
      model.setMetaInfo(modelJson.toString());
      model.setName(values.getFirst("name"));
      
      repositoryService.saveModel(model);
      
      repositoryService.addModelEditorSource(model.getId(), values.getFirst("json_xml").getBytes("utf-8"));
      
     /* InputStream svgStream = new ByteArrayInputStream(values.getFirst("svg_xml").getBytes("utf-8"));
      TranscoderInput input = new TranscoderInput(svgStream);
      
      PNGTranscoder transcoder = new PNGTranscoder();
      // Setup output
      ByteArrayOutputStream outStream = new ByteArrayOutputStream();
      TranscoderOutput output = new TranscoderOutput(outStream);
      
      // Do the transformation
      transcoder.transcode(input, output);
      final byte[] result = outStream.toByteArray();
      repositoryService.addModelEditorSourceExtra(model.getId(), result);
      outStream.close();*/
      
    } catch (Exception e) {
      LOGGER.error("Error saving model", e);
      throw new ActivitiException("Error saving model", e);
    }
  }
}

这样就是在保存modeler之后不会再数据库生成图片的资源,不过这里推荐一种,就是平常用model生成的json部署的时候使用bpmn的生成图片方法activiti-image-generator-5.18.0 这样既可以不用引入batik的jar,也可以使用activiti的jar即可,而且和流程定义的生成图是一样。

转载于:https://my.oschina.net/u/1261308/blog/490389

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
全管C5-OA协同办公管理软件功能了涵盖了事务、流程、交流、知识、后勤、人事、考勤、薪酬、财务等企业办公管理的各个方面。 全管C5-OA采用B/S架构,在单机、局域网以及互联网上均可部署使用,支持总部与异地多分支机构管理模式,实现与异地分支机构的实时交互。可无缝升级至CRM客户关系管理以及ERP企业全面管理。 功能全面的OA系统 功能全面的OA系统 涵盖企业办公管理的各个方面:工作流、待办清单、日常任务、报告、公告通知、在线消息、手机短信、电子邮件、微信集成、知识库、通讯录、网址库、物流快递、物品借用、消耗品领用、车辆使用、会议安排、固定资产管理、设备管理、组织结构、考勤管理、薪酬管理、招聘管理、劳动合同、费用报销、借款、还款、出纳管理、现金银行、资金转款等,提供全面而完善的管理。 高效的时间管理,大小事务一览无遗 待办清单(TODO)从时间管理的角度整合了分散在各个功能模块中的大小事务,并集中查询和管理,提供多种视图形式,能够显著提升工作效率。 灵活的工作流引擎,随需应变 灵活的工作流引擎设计,不仅可用于自定义表单,还可用于系统级表单的流转。支持多种条件跳转、自定义处理动作、工作流分支与汇聚、条件路由流转、多角色活动参与人、活动任一/会签/投票机制、活动参与人绑定等等。 增强的人力资源管理,特色功能解决复杂的人事管理 增强的人力资源管理功能,包括:组织结构管理、人事档案管理、招聘管理、劳动合同管理、考勤排班管理、薪酬管理。特色功能有:采用职员、职位和部门相互联系的组织结构,支持一人多岗及矩阵式管理。排班支持常白班和轮班。薪酬管理支持多薪酬账套和多社保账套,支持单独调整和重算。 实用的后勤管理,独创企业虚拟资产管理 提供实用的后勤管理功能,如:物流快递收发管理、物品借用管理、消耗品领用管理、车辆使用管理、会议安排管理、固定资产管理、设备管理等等。 多维度权限机制,轻松应对变化 在角色权限的基础上,结合组织结构扩展出四类角色:部门、职位、人员组及职员,可分别对这四种角色设置权限,系统自动合并计算出最终权限。与传统单一维度权限机制相比,多维度权限机制功能更强大,管理效率也更高,可以大大减少因人员变动而产生的权限调整工作量。 个性化实施方案,贴合管理需求 除了通用的标准化实施方案以外,我们还可以提供个性化的实施方案,可以根据您的个性化需求对产品进行调整。 得益于自主研发的元模型平台,我们的个性化实施在深度与广度方面都具有独特的优势。同时由于采用新技术带来的效率提升,我们的个性化实施方案在时间和成本方面都大大优于传统编程二次开发方式。 体验式销售模式,让企业放心 我们为您提供了多种途径来全方位了解产品,除了在线的产品介绍资料以外,您可以直接进入在线观摩系统(无需注册申请)来亲自体验我们的产品。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值