疯狂Activiti6.0连载(22)流程存储Web Service

 本文节选自《疯狂Workflow讲义(第2版)》

京东购买地址:https://item.jd.com/12246565.html

工作流Activiti6电子书http://blog.csdn.net/boxiong86/article/details/78488562

工作流Activiti6教学视频http://blog.csdn.net/boxiong86/article/details/78608585

流程存储Web Service

Activiti的所发布的WebService,主要是调用流程引擎的各个服务组件,操作流程相关数据,这些操作包括增加、查询、删除、数据修改和文件上传,从本小节开始,将讲解这部分WebService使用注意下,本章的全部例子均使用CXFAPI来编写请求客户端。

上传部署文件

Activiti发布了一个/deployment接口,调用该接口可以将流程相关的文件远程部署到流程引擎中,目前支持的格式有.bpmn.bpmn20.xml.bar.zip文件。部署activiti-rest后,这个接口的访问地址为http://localhost:8080/activiti-rest/service/deployment/deployment接口成功接收请求后,会调用RepositoryService().createDeployment()等一系列方法添加资源文件并且进行部署RepositoryService的使用详细请见流程存储章节代码清单17-9为客户端代码。

代码清单17-9codes\17\rs-client\src\org\crazyit\activiti\rest\TestDeployment.java

        //创建WebClient,设置URL、认证用户名和密码

        WebClient client = WebClient.create(

                "http://localhost:8080/activiti-rest/service/repository/deployments",

                "crazyit", "123456", null);

        //设置认证格式为基础认证格式

        String authorizationHeader = "Basic "

                + org.apache.cxf.common.util.Base64Utility

                        .encode("user:password".getBytes());

        client.header("Authorization", authorizationHeader);

        //设置内容类型

        client.type("multipart/form-data");

        //获取上传文件

        String path = TestDeployment.class.getResource("/").toString();

        File file = new File(new URI(path + "bpmn/DeploymentUpload.bpmn20.xml"));

        //一定需要name属性

        ContentDisposition cd = new ContentDisposition(

                "form-data; name=deployment; filename=DeploymentUpload.bpmn20.xml");

        Attachment att = new Attachment(null, new FileInputStream(file), cd);

        //获取响应,使用POS方法

        Response response = client.post(new MultipartBody(att));

        //获取响应内容

        InputStream ent = (InputStream) response.getEntity();

        String content = IOUtils.readStringFromStream(ent);

        //输出响应字符串

        System.out.println(content);

调用时需要注意,在构建ContentDisposition实例时,必须提供name属性,filename属性的文件名称后缀必须为.bpmn.bpmn20.xml.bar.zip,否则接口会返回:“File must be of type .bpmn20.xml, .bpmn, .bar or .zip”这样的异常信息。成功调用接口后,返回以下JSON

{

    "id": "3801",

    "name": "DeploymentUpload.bpmn20.xml",

    "deploymentTime": "2017-07-23T07:34:24.496+08:00",

    "category": null,

    "url": "http://localhost:8080/activiti-rest/service/repository/deployments/3801",

    "tenantId": ""

}

部署数据查询

使用部署数据查询接口,可以分页查询多个部署数据,接口调用的地址为:repository/deployments,地址后可接多个参数,代码清单17-10为接口调用代码。

代码清单17-10codes\17\rs-client\src\org\crazyit\activiti\rest\TestDeployments.java

        //创建WebClient,设置URL、认证用户名和密码

        WebClient client = WebClient

                .create("http://localhost:8080/activiti-rest/service/"

                        + "repository/deployments?sort=name&nameLike=%processes",

                        "crazyit", "123456", null);

        //设置认证格式为基础认证格式

        String authorizationHeader = "Basic "

                + org.apache.cxf.common.util.Base64Utility

                        .encode("user:password".getBytes());

        client.header("Authorization", authorizationHeader);

        //获取响应

        Response response = client.get();

        //获取响应内容

        InputStream ent = (InputStream) response.getEntity();

        String content = IOUtils.readStringFromStream(ent);

        //输出字符串

        System.out.println(content);

代码清单17-10中的粗体字代码,加入了sort参数进行按name字段进行排序,使用nameLike参数进行名称的模糊查询,在使用模糊查询时,注意需要传入通配符。调用接口后返回以下JSON字符串:

{

    "data": [

        {

            "id": "1320",

            "name": "Demo processes",

            "deploymentTime": "2017-07-22T08:36:48.793+08:00",

            "category": null,

            "url": "http://localhost:8080/activiti-rest/service/repository/deployments/1320",

            "tenantId": ""

        }

    ],

    "total": 1,

    "start": 0,

    "sort": "name",

    "order": "asc",

    "size": 1

}

部署资源查询

部署过程可以部署多个资源文件,查询这些资源可以使用repository/deployments/{deploymentId }/resources接口,传入部署数据的ID代码清单17-15为测试代码。

代码清单17-11codes\17\rs-client\src\org\crazyit\activiti\rest\QueryResources.java

        //创建WebClient,设置URL、认证用户名和密码

        WebClient client =WebClient

                .create("http://localhost:8080/activiti-rest/service/"

                        + "repository/deployments/1001/resources",

                        "crazyit", "123456", null);

        //设置认证格式为基础认证格式

        String authorizationHeader = "Basic "

                + org.apache.cxf.common.util.Base64Utility

                        .encode("user:password".getBytes());

        client.header("Authorization", authorizationHeader);

        //获取响应

        Response response = client.get();

       //获取响应内容

        InputStream ent = (InputStream) response.getEntity();

        String content = IOUtils.readStringFromStream(ent);

        //输出字符串

        System.out.println(content);

调用接口成功后,返回以下JSON

[

    {

        "id": "bpmn/TaskExternalForm.bpmn",

        "url": "http://localhost:8080/activiti-rest/service/repository/deployments/1001/resources/bpmn/TaskExternalForm.bpmn",

        "contentUrl": "http://localhost:8080/activiti-rest/service/repository/deployments/1001/resourcedata/bpmn/TaskExternalForm.bpmn",

        "mediaType": "text/xml",

        "type": "processDefinition"

    },

    {

        "id": "forms/TaskExternalForm.form",

        "url": "http://localhost:8080/activiti-rest/service/repository/deployments/1001/resources/forms/TaskExternalForm.form",

        "contentUrl": "http://localhost:8080/activiti-rest/service/repository/deployments/1001/resourcedata/forms/TaskExternalForm.form",

        "mediaType": null,

        "type": "resource"

    }

]

 

查询单个部署资源

查询单个部署资源,使用repository/deployments/{deploymentId}/resources/{resourceId}接口,调用时要传入部署数据的id以及资源id,注意资源id并不是资源表的ID_字段,而是由“部署资源查询”接口返回的id,对应的是数据库中的NAME_字段,代码清单17-12调用该接口。

代码清单17-12codes\17\rs-client\src\org\crazyit\activiti\rest\QueryResource.java

        //创建WebClient,设置URL、认证用户名和密码

        WebClient client = WebClient

                .create("http://localhost:8080/activiti-rest/service/"

                        + "repository/deployments/1001/resources/bpmn/TaskExternalForm.bpmn",

                        "crazyit", "123456", null);

        //设置认证格式为基础认证格式

        String authorizationHeader = "Basic "

                + org.apache.cxf.common.util.Base64Utility

                        .encode("user:password".getBytes());

        client.header("Authorization", authorizationHeader);

        //获取响应

        Response response = client.get();

        //获取响应内容

        InputStream ent = (InputStream) response.getEntity();

        String content = IOUtils.readStringFromStream(ent);

        //输出字符串

        System.out.println(content);

调用接口后,返回的JSON如下:

{

    "id": "bpmn/TaskExternalForm.bpmn",

    "url": "http://localhost:8080/activiti-rest/service/repository/deployments/1001/resources/bpmn/TaskExternalForm.bpmn",

    "contentUrl": "http://localhost:8080/activiti-rest/service/repository/deployments/1001/resourcedata/bpmn/TaskExternalForm.bpmn",

    "mediaType": "text/xml",

    "type": "processDefinition"

}

删除部署

上传部署文件的方法,使用的是HTTPPOST方法,而前面的几个部署数据查询方法,使用的则是GET方法,删除部署,需要使用DELETE方法。删除部署的URLrepository/deployments/{deploymentId }调用该接口后,如果删除成功并不会返回结果如果删除失败,则会返回异常信息代码清单17-13为测试代码

代码清单17-13codes\17\rs-client\src\org\crazyit\activiti\rest\DeleteDeployment.java

        //创建WebClient,设置URL、认证用户名和密码

        WebClient client = WebClient

                .create("http://localhost:8080/activiti-rest/service/"

                        + "repository/deployments/3807",

                        "crazyit", "123456", null);

        //设置认证格式为基础认证格式

        String authorizationHeader = "Basic "

                + org.apache.cxf.common.util.Base64Utility

                        .encode("user:password".getBytes());

        client.header("Authorization", authorizationHeader);

        //获取响应

        Response response = client.delete();

        //获取响应内容

        InputStream ent = (InputStream) response.getEntity();

        String content = IOUtils.readStringFromStream(ent);

        //输出字符串(本例并不会有响应内容)

        System.out.println(content);

在使用删除部署接口时,需要注意以下细节:

     成功删除后,不会返回JSON数据。

     如果被删除的部署数据id不存在,接口则会接收到异常信息:Could not find a deployment with id

     如果被删除的部署已经产生的外键关联(例如启动了流程实例),同样会删除失败。

除了流程存储模块发布的接口,其他模块也提供了大量操作流程引擎的接口,所谓一通百通,其他接口的调用,在此不再赘述。

京东购买地址:https://item.jd.com/12246565.html

工作流Activiti6电子书http://blog.csdn.net/boxiong86/article/details/78488562

工作流Activiti6教学视频http://blog.csdn.net/boxiong86/article/details/78608585

本书代码共享地址:https://gitee.com/yangenxiong/CrazyActiviti

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
1. 初识Activiti 1.1. 工作流与工作流引擎 工作流(workflow)就是工作流程的计算模型,即将工作流程中的工作如何前后组织在一起的逻辑和规则在计算机中以恰当的模型进行表示并对其实施计算。它主要解决的是“使在多个参与者之间按照某种预定义的规则传递文档、信息或任务的过程自动进行,从而实现某个预期的业务目标,或者促使此目标的实现”。(我的理解就是:将部分或者全部的工作流程、逻辑让计算机帮你来处理,实现自动化) 所谓工作流引擎是指workflow作为应用系统的一部分,并为之提供对各应用系统有决定作用的根据角色、分工和条件的不同决定信息传递路由、内容等级等核心解决方案。 例如开发一个系统最关键的部分不是系统的界面,也不是和数据库之间的信息交换,而是如何根据业务逻辑开发出符合实际需要的程序逻辑并确保其稳定性、易维护性和弹性。 比如你的系统中有一个任务流程,一般情况下这个任务的代码逻辑、流程你都要自己来编写。实现它是没有问题的。但是谁能保证逻辑编写的毫无纰漏?经过无数次的测试与改进,这个流程没有任何漏洞也是可以实现的,但是明显就会拖慢整个项目的进度。 工作流引擎解决的就是这个问题:如果应用程序缺乏强大的逻辑层,势必变得容易出错(信息的路由错误、死循环等等)。 1.2. BPMN2.0规范 BPMN(Business Process Model and Notation)--业务流程模型与符号。 BPMN是一套流程建模的标准,主要目标是被所有业务用户容易理解的符号,支持从创建流程轮廓的业务分析到这些流程的最终实现,知道最终用户的管理监控。 通俗一点其实就是一套规范,画流程模型的规范。流程模型包括:流程图、协作图、编排图、会话图。详细信息请google。 1.3. Activiti概述 1.3.1. Activiti由来 学习过Activiti的朋友都知道,Activiti的创始人也就是JBPM(也是一个优秀的BPM引擎)的创始人,从Jboss离职后开发了一个新的BPM引擎:Activiti。所以,Activiti有很多地方都有JBPM的影子。所以,据说学习过JBPM的朋友学起Activiti来非常顺手。 由于本人之前没有工作流及JBPM的相关基础,刚开始学习Activiti的时候可以说是无比痛苦的,根本不知道从何下手,这里也建议大家先进行工作流及BPMN2.0规范的学习,有了一定的基础后,再着手学习Activiti。 1.3.2. Activiti简介 Activiti是一个开源的工作流引擎,它实现了BPMN 2.0规范,可以发布设计好的流程定义,并通过api进行流程调度。 Activiti 作为一个遵从 Apache 许可的工作流和业务流程管理开源平台,其核心是基于 Java 的超快速、超稳定的 BPMN2.0 流程引擎,强调流程服务的可嵌入性和可扩展性,同时更加强调面向业务人员。 Activiti 流程引擎重点关注在系统开发的易用性和轻量性上。每一项 BPM 业务功能 Activiti 流程引擎都以服务的形式提供给开发人员。通过使用这些服务,开发人员能够构建出功能丰富、轻便且高效的 BPM 应用程序。 1.4. 文档说明 以上部分对工作流、BPMN、Activiti的概念做了一个简单的介绍,目的是了解Activiti究竟是什么,能做些什么…及在学习Activiti之前需要了解的知识与技术。其中大部分文字来自Copy网上的各种资料与文档,通过总结而来的。具体的更详细的内容需自己google,参考一些官方的文档与手册。 本文档之后内容如下: 1) 下载与使用 2) 核心组件与说明 3) 入门示例 4) Eclipse中的Activiti插件的使用 本文档旨在为初学Activiti的朋友提供入门级别的参考,不会对其原理及其结构进行深层次的探究(更多是因为目前自身理解还不是很透彻),只是为大家理清思路,方便以后更深层次的学习。本文档还有一个重要的特点,那就是根据自己看官方手册的经验,教大家如何看手册从而更有效率!由于是初学,很多术语或解释难免理解有偏差,所以一定要看官方提供的文档与手册,那才是学习的最佳途径! 2. 开始学习 2.1. 必要的准备 2.1.1. 下载与了解目录 下载Activiti:下载路径,也就是官方网站的地址:http://activiti.org/download.html。下载后解压(我所使用的是5.12版本的,Activiti更新速度飞快,几乎每两个月就会有一个更新的小版本),看到如下目录: 1) database:里面存放的是Activiti使用到的数据库信息的sql文件,它支持的数据库类型如下图,使用时只需执行你自己的数据库类型
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

杨大仙的程序空间

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值