项目开发总结:基于服务编排的银行产品系统

本文介绍了团队在上海市计算机能力应用大赛中,基于Jeecg-boot和activiti7开发的项目,通过原子服务实现快速产品发布和后台功能组合。着重讲述了原子服务的设计、前端与后端交互、难点解决策略,以及如何利用反射机制处理ServiceTask的Java实现。

前言

本项目是为了参加上海市计算机能力应用大赛而和同学一起开发的项目,这个项目的灵感最初是来自服务外包创新设计大赛的一个银行的需求,这个需求是为了让产品能快速上线而设计的,因为每个产品上线,它对应的后台功能是不一样的,这里我们使用流程审批功能去实现,然而不同的后台功能也是可以经过若干个小事务组合的,这里就涉及到了原子服务的概念,我们需要将流程中的节点作为一个能够实现某组原子性功能的东西。

实现目标

一方面要能够实现发布不同的产品,另一方面要能够实现让管理员通过组合不同的原子服务以快速构成一个产品的功能流程并发布。

项目概述

本项目是基于一个Jeecg-boot整合activiti7和bpmn.js工作流的二次开源项目的基础上改造的。这很方便,因为jeecg-boot开发平台帮我们已经搭建好了一个ERP管理系统,我们只需要在这基础上开发就好;此外开源作者已经整合了activiti7的工作流引擎,所以我们的重点就是如何抽象出这个原子服务,并组合这个服务。

实现过程

首先是原子服务如何实现。这分为两部分,原子服务需要映射到流程设计器的图标上,要做到能够拖拽,此外还需要有对应的后端实现。
我们借用工作流中的任务类来实现原子服务,审批的部分交给UserTask类,而产品其余的后端处理交给ServiceTask类去实现,主要的原子服务其实是ServiceTask类,我们需要修改图标并将图标与后端的Java类绑定。
修改映射图标是bpmn.js的前端部分,我们需要自定义palette上的用户类图标,修改它的默认参数;修改类型参数将它设置成默认ServiceTask,并且将对应后端Java类的默认值设置为对应的后端Java类的包名。这些修改都是在customPalette.js中实现的,bpmn使用了一个工厂类来统一管理palette面板的生成。
原子服务我们将它抽象出来作为一张数据表存储在数据库中,与后端Java类的绑定需要我们在渲染出这个palette的时候调用数据库提取出数据表信息,上一步的ServiceTask对应的Java类名必须从数据库提取
原子服务的实现就是工作流引擎后端部分要实现的,要将ServiceTask的处理逻辑都写在一个继承了JavaDelegate类的Java类中。
接着是产品的购买逻辑部分,这里我们给用户增加一个余额字段,用户的购买就是不同用户之间的余额转移,还有创建了一个购买记录表,负责记录购买的记录。
最后是产品与对应的处理流程的绑定,需要做到用户发起购买的同时启动这个流程,我们实现了在前端通过点击进行绑定

项目难点与解决

1.前端的原子服务图标读取原子服务数据时存在异步访问的时序问题。通常情况下我们获取数据是用ajax来获取的,但是问题就在ajax是异步执行的,它会让程序继续执行,直到自己处理完毕再让主程序读取数据。在本项目中,等原子服务渲染好了,ajax的数据还没有读取到,而原子服务图标的渲染是紧跟着流程设计器面板的渲染的,流程设计器渲染时也需要用ajax从后端读取信息,这导致我们使用async和await关键字都无法实现正常执行流程,最后我们还是使用了vuex实现,在进入流程设计器页面之前就读取原子服务信息并放入vuex中统一保存,这样就避免了时序混乱的问题。
2.ServiceTask的Java实现类中无法注入外部字段,在购买产品时我们需要对应的产品购买的service层,而activiti引擎由于单例模式的存在,限制注入字段,这里我们采用了java的反射机制,直接读取spring框架的上下文来获取service的bean。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值