activiti 通过xml上传 直接部署模型

通过流程xml 直接先发布模型,然后再通过发布模型之后的流程定义获取bpmn model来创建Model.

1、通过xml先发布模型

bash 复制代码
InputStream bpmnStream = multipartFile.getInputStream()
deployment = repositoryService.createDeployment()
                    .addInputStream(multipartFile.getOriginalFilename(), bpmnStream).deploy();
            List<ProcessDefinition> list = repositoryService.createProcessDefinitionQuery()
                    .deploymentId(deployment.getId()).list();
            String processDefinitionId = list.get(0).getId();
            convertToModel(processDefinitionId);

2. 发布之后 通过流程定义获取bpmn model新建model

注意这里的addModelEditorSource addModelEditorSourceExtra获取。

bash 复制代码
 Model modelData = repositoryService.newModel();
        ProcessDefinition processDefinition = repositoryService.createProcessDefinitionQuery()
                .processDefinitionId(processDefinitionId).singleResult();
        InputStream bpmnStream = repositoryService.getResourceAsStream(processDefinition.getDeploymentId(),
                processDefinition.getResourceName());
        XMLInputFactory xif = XMLInputFactory.newInstance();
        InputStreamReader in = new InputStreamReader(bpmnStream, "UTF-8");
        XMLStreamReader xtr = xif.createXMLStreamReader(in);
        BpmnModel bpmnModel = new BpmnXMLConverter().convertToBpmnModel(xtr);
        BpmnJsonConverter converter = new BpmnJsonConverter();
        com.fasterxml.jackson.databind.node.ObjectNode modelNode = converter.convertToJson(bpmnModel);
        modelData.setKey(processDefinition.getKey());
        modelData.setName(processDefinition.getKey());
        ObjectNode modelObjectNode = objectMapper.createObjectNode();
        modelObjectNode.put(ModelDataJsonConstants.MODEL_NAME, processDefinition.getResourceName());
        modelObjectNode.put(ModelDataJsonConstants.MODEL_REVISION, 1);// 版本
        modelObjectNode.put(ModelDataJsonConstants.MODEL_DESCRIPTION,processDefinition.getResourceName());
        modelData.setMetaInfo(modelObjectNode.toString());
        repositoryService.saveModel(modelData);
        DefaultProcessDiagramGenerator generator = new DefaultProcessDiagramGenerator();
        generator.generateDiagram(bpmnModel,  new ArrayList<>());
        ByteArrayOutputStream bos = new ByteArrayOutputStream();
        IoUtil.copy(bpmnStream, bos);
        byte[] bytes = bos.toByteArray();
        repositoryService.addModelEditorSource(modelData.getId(), modelNode.toString().getBytes("utf-8"));
        repositoryService.addModelEditorSourceExtra(
                modelData.getId(), bytes);
        deploy(modelData.getId());
相关推荐
hmywillstronger22 分钟前
【Python】从SAP2000 XML截面库提取数据到Excel
xml·python·excel
Boop_wu1 小时前
[Mybatis] XML 方式实现 MP 自定义 SQL + 条件构造器
xml·sql·mybatis
曹牧15 小时前
Oracle:将包含属性(Attributes)的 XML 数据解析为表格数据
xml·数据库·oracle
阿维的博客日记1 天前
传统 Spring XML 配置 vs Spring Boot Starter 对比文档
xml·spring boot·spring
Cx330❀4 天前
Qt 入门指南:从零搭建开发环境到第一个图形界面程序
xml·大数据·开发语言·网络·c++·人工智能·qt
常利兵5 天前
Android字体字重设置全攻略:XML黑科技+Kotlin动态实现,告别.ttf臃肿
android·xml·科技
hhb_6186 天前
XML数据解析与节点配置实操案例教程
xml
不会编程的懒洋洋10 天前
WPF XAML+布局+控件
xml·开发语言·c#·视觉检测·wpf·机器视觉·视图
鸽芷咕11 天前
KingbaseES数据类型完全指南:从基础CHAR到JSON/XML/几何类型
xml·oracle·json
java1234_小锋15 天前
MyBatis中XML映射有哪些标签?
xml·tomcat·mybatis