一种通用化智能审核平台及其审核方法与流程

文档序号:12721991阅读:506来源:国知局
一种通用化智能审核平台及其审核方法与流程

本发明涉及业务数据智能审核技术领域,还涉及面向医疗保险报销审核、企业报销审核以及行政审批等数据审核领域,尤其涉及一种通用化智能审核平台及其审核方法。



背景技术:

国家经济下行压力不断加大,市场竞争越发激烈,企业运营风险不断增加的环境下,企业和机构为了提高自身市场竞争力,在优胜劣汰的市场竞争中优胜,普遍做法是开源节流,减少不必要的日常运营开销,提高资源管理水平,提高投入资源产出率。在市场需求推动下,业务数据审核进入了快速增长期。但是现有业务数据审核模式存在以下问题:

面对大量业务数据审核任务,传统人工审核模式,不仅审核时间长、审核效率低,异常数据甄别能力低,同时造成审核人员工作负担过大,影响身心健康。随着数据时代到来,业务数据审核需求越来越大,审核要求越来越高,传统人工审核模式的问题将异常突出。

目前,市场上存在一些业务数据审核平台,比如申请号为CN201510464287.8、名称为“一种大病医保智能化审核系统及审核算法” 的发明专利,该发明提供一种大病医保智能化审核系统,包括数据库模块、智能审核引擎以及基础信息库管理模块,所述数据库模块,用于获取大病医保数据;所述智能审核引擎,其用于对所述大病医保数据的各属性项的关联匹配度进行审核处理;所述基础信息库管理模块,其存储基础数据的各项属性信息,其中,所述智能审核引擎分别与所述数据库模块、所述基础信息库管理模块连接,并给予所述数据库模块、所述基础信息库管理模块的数据完成所述审核处理。但这审核平台业务审核范围单一,审核领域局限,只能处理特定审核领域,无法扩展审核范围和审核领域。虽然可以满足当前业务数据审核需求,但是市场是动态不断变化的,实际业务需求也随之不断变化,这些审核范围单一、审核领域局限的数据审核平台,终将在残酷的市场竞争中淘汰。

同时,现有技术在审核平台开发时关心实际处理的业务数据,具体地:现在大多数审核平台,在开发时已经默认设置需要处理的业务数据结构,部署后只能解析与默认设置的业务数据结构相对应的业务数据,突出审核平台处理业务数据范围的局限性,导致这种审核平台存在缺陷。因为实际的业务数据结构总是随着市场的不断变化而动态变化,所以审核平台的业务数据结构也需要随之改变,但是这种审核平台已经在开发时将需求方提供的业务数据结构固化在代码。平台部署后想要修改业务数据结构,则需要修改审核平台源代码,加大了审核平台的维护成本和风险。当审核平台部署发布后,修改源代码风险极高,极有可能在修改代码过程中影响其他部分功能模块,从而留下隐蔽Bug。为了规避这些风险,需要测试人员投入大量精力对审核平台稳定性进行测试,这无疑加大审核平台的开发、运营和维护成本。

另外,市面上大多数审核平台,需要在开发时确定具体的业务审核逻辑,并在开发过程中固化在代码里。这样大大降低了系统的扩展性和灵活性,实际业务审核逻辑并不是一成不变的,而是随着市场需求的变化而变化。这种预先把业务审核逻辑的固化到系统里的设计模式终将在优胜劣汰的市场中,暴露出巨大的缺陷,从而慢慢被残酷的市场所淘汰。如果为了弥补这一缺陷去修改源代码,不仅加大了开发、测试和维护成本,而且降低了系统的可用性和稳定性。

最后,现在市面上大多数审核平台,只支持单一的审核方式,本应有所区分的审核应用场景,由于设计开发时没有考虑有选择的审核方式,导致对于所有的审核请求,都采取单一审核方式,显然这样是不合理的。



技术实现要素:

本发明的目的在于克服现有技术的不足,提供一种通用化智能审核平台及其审核方法,在审核平台开发和部署时将业务数据和业务审核逻辑进行无关化处理,提高系统的可用性和稳定性,降低审核平台的开发、运营和维护成本。

本发明的目的是通过以下技术方案来实现的:一种通用化智能审核平台,包括项目构建模块和智能审核模块;

所述的项目构建模块用于管理项目库;所述的项目库中包括至少一个实例化项目;所述的项目构建模块包括业务数据单元、业务数据库单元、业务JavaBean单元和业务规则单元;所述的业务数据单元用于构建实例化项目的业务数据结构,所述的业务数据结构由数据表信息和字段信息组成,为解析审核请求方上传JSON数据包提供支持,同时为业务数据库单元、业务JavaBean单元和业务规则单元提供支持;所述的业务数据库单元用于构建基于所述实例化项目的业务数据结构的业务数据库,为持久化审核数据提供物理存储支持;所述的业务JavaBean单元用于构建基于所述实例化项目的业务数据结构的业务JavaBean集,当智能审核模块的审核请求到达时,将审核数据转换为实例化业务JavaBean对象;所述的业务规则单元用于构建基于所述实例化项目的业务数据结构的业务规则库,包括将实例化项目的业务审核逻辑转换为Drools规则引擎支持的规则和规则流;

所述的智能审核模块用于实现审核平台的业务数据审核。

所述的智能审核模块包括事中审核单元和事后审核单元;所述的事中审核单元用于实时性高、响应速度快、数据量小的业务审核应用场景,所述的事后审核单元用于实时性低、响应速度较快、数据量大的业务审核应用场景;

所述的事中审核单元包括第一审核数据接口子单元、第一任务管理子单元和事中审核引擎,所述的第一审核数据接口子单元负责管理审核平台和审核请求方之间的数据通信,包括监听审核请求、解析审核请求和审核结果传回;所述的第一任务管理子单元负责管理审核任务,包括维护任务表、创建审核任务、更改任务状态和结束审核任务,所有审核任务信息记录在任务表中;所述的事中审核引擎负责处理事中审核的业务数据审核;

所述的事后审核单元包括第二审核数据接口子单元、第二任务管理子单元和事后审核引擎,所述的第二审核数据接口子单元负责管理审核平台和审核请求方之间的数据通信,包括监听审核请求、解析审核请求和审核结果传回;所述的第二任务管理子单元负责管理审核任务,包括维护任务表、创建审核任务、更改任务状态和结束审核任务,所有审核任务信息记录在任务表中;所述的事后审核引擎负责处理事后审核的业务数据审核。

所述的事中审核引擎为线性执行的非流水线方式的审核引擎;所述的事中审核引擎包括业务数据审核组件、审核结果组装组件和审核任务持久化组件,所述的业务数据审核组件用于审核业务数据,所述的审核结果组装组件用于按返回结果标准格式组装审核结果,所述的审核任务持久化组件用于将审核任务信息、业务数据和审核结果持久化到物理数据库。

所述的事后审核引擎为并行执行的流水线方式的审核引擎;所述的事中审核引擎包括业务数据审核组件、审核结果组装组件、结果传回组件和审核任务持久化组件,所述的业务数据审核组件用于审核业务数据,所述的审核结果组装组件用于按返回结果标准格式组装审核结果,所述的结果传回组件基于第二审核数据接口子单元将组装的审核结果传回审核请求方,所述的审核任务持久化组件用于将审核任务信息、业务数据和审核结果持久化到物理数据库。

一种通用化智能审核方法,包括项目构建步骤和智能审核步骤;所述的项目构建步骤包括对实例化项目的添加,所述的对实例化项目的添加包括以下子步骤:

S11:添加实例化项目,对实例化项目的基本信息进行添加;

S12:添加至少一个业务数据结构,包括对数据表信息和字段信息的添加;同时在添加完成后,系统为所述业务数据结构添加任务编号字段和任务数据索引字段;

S13:在步骤S12完成后,分别构建业务数据库、业务JavaBean集和业务规则库;其中,对于业务数据库的构建包括以下子步骤:

S1311:根据业务数据结构的数据表编号和与该数据表编号绑定的字段信息,构造数据表SQL语句;

S1312:在实例化项目业务数据库中执行构造的SQL语句,完成业务数据表创建,更新该业务数据结构数据表信息的生成标志,表明业务数据表已生成;

S1313:将实例化项目的所有业务数据结构一一生成对应的业务数据表;

对于业务JavaBean集的构建,包括以下子步骤:

S1321:根据该业务数据结构的数据表编号和与该数据表编号绑定的字段信息,构造对应业务JavaBean的java文件;

S1322:使用java语言编程编译器javac将java文件编译生成class文件,更新该业务数据结构数据表信息的生成标志,表明业务JavaBean已生成;

S1323:将实例化项目的所有业务数据结构一一生成对应的业务JavaBean,构建业务JavaBean集;

对于业务规则库的构建,包括以下子步骤:

S1331:构建规则部分,所述的规则部分包括属性部分、条件部分和结构部分;所述的属性部分用于定义当前规则执行的一些属性,包括是否可被重复执行、过期时间、生效时间;所述的条件部分用于定义当前规则的单个/多个条件;所述的结构部分用于定义满足当前条件部分后执行的操作;

S1332:构建规则流,所述的规则流基于业务流程图实现,所述的业务流程图描述了一系列需要执行的审核业务的顺序,包括规则部分、条件分支和分支聚合三部分;

所述的智能审核步骤用于实现审核平台的业务数据审核。

所述的实例化项目的基本信息包括项目名、项目编号、项目介绍、业务数据库账号和密码;在提交添加申请后,在数据库创建对应的数据库账号,创建的数据库账号作为实例化项目的业务数据库,存储实例化项目的业务数据;

所述的数据表信息包括数据表编号和生成标志;所述的生成标志表示该数据表信息是否生成对应业务JavaBean,以及是否在数据库中生成对应业务数据表;所述的数据表编号作为业务数据表的表名和业务JavaBean的类名;

所述的字段信息包括字段编号和关心标识,所述的字段编号作为业务数据表的字段名和业务JavaBean的类成员变量名,所述的关心标识表示该字段是否为关心数据,在业务审核时,当该数据表数据触发了业务规则,需要将关心标识的字段数据拼接在审核结果,返回给审核请求方。

所述的项目构建步骤还包括对实例化项目的修改、查看与删除。

所述的智能审核步骤包括事中审核子步骤和事后审核子步骤;所述的事中审核子步骤为线性执行的非流水线方式,所述的事后审核子步骤为并行执行的流水线方式。

所述的事中审核子步骤,包括以下子步骤:

S211:事中审核数据接口捕获审核请求;其中所述的审核请求为审核请求方将验证信息、审核要求和业务数据封装成JSON数据包,然后加密压缩并设置为接口输入数据,传输到审核平台的事中审核数据接口的审核请求;

S212:事中审核数据接口将上传数据解压解密,解析出验证信息,将验证信息与审核服务注册信息进行对比验证,如果验证通过,则进入步骤S213;否则,事中审核数据接口将审核服务受限提示信息返回审核请求方;

S213:事中审核数据接口解析审核要求,如果审核要求解析成功,则通过任务管理子单元创建审核任务、初始化审核任务、绑定请求方信息、设置审核要求,并进入步骤S214;否则,事中审核数据接口将错误信息返回审核请求方;

S214:事中审核数据接口基于业务数据结构解析业务数据,如果业务数据解析成功,事中审核数据接口将业务数据转换为实例化业务JavaBean对象,转入事中审核引擎进行业务审核;否则,任务管理子单元注销审核任务,事中审核数据接口将错误信息返回审核请求方;

S215:事中审核引擎根据审核任务的审核要求,从编译后的业务规则库提取本次审核涉及的业务规则包,并基于提取的业务规则包,创建审核会话,将业务数据JavaBean对象加载到审核会话中,执行审核会话;

S216:审核会话结束后,按返回结果标准格式组装审核结果;

S217:组装完成后,事中审核数据接口模块根据审核任务绑定的请求方的地址,将组装结果加密压缩,发送给审核请求方;同时,在发送成功后,将审核相关数据和审核任务信息备份到数据库,实现审核任务持久化,任务管理更改任务审核状态为审核成功,审核线程结束并将审核线程返还线程池,整个事中审核完成。

所述的事后审核子步骤,包括以下子步骤:

S221:事后审核数据接口捕获审核请求;其中所述的审核请求为审核请求方将验证信息、审核要求和业务数据封装成JSON数据包,然后加密压缩并设置为接口输入数据,传输到审核平台的审核请求;

S222:事后审核数据接口将上传数据解压解密,解析出验证信息,将验证信息与审核服务注册信息进行对比验证,如果验证通过,则进入步骤S223;否则,事后审核数据接口将审核服务受限提示信息返回审核请求方;

S223:事后审核数据接口解析审核要求,如果审核要求解析成功,则任务管理子单元创建审核任务、初始化审核任务、绑定请求方信息、设置审核要求,设置任务状态为审核数据待解析,并进入步骤S224;否则,事后审核数据接口将错误信息返回给审核请求方,线程结束并将线程返还线程池;

S224:事后审核数据接口基于业务数据结构解析业务数据,如果解析业务数据成功,事后审核数据接口将业务数据转换为业务JavaBean对象,业务JavaBean对象绑定审核任务号,保存到内存缓存,将审核任务挂载到待审核队列,更改任务状态为待审核,转入事后审核引擎进行业务审核,返回审核任务号给审核请求方,线程结束并将线程返还线程池,进入步骤S225;否则,更改任务状态为审核数据解析失败,将错误信息返回给审核请求方,线程结束并将线程返还线程池;

S225:事后审核引擎的审核组件、组装组件、结果传回组件和备份组件分别对对应队列进行处理:

(1)审核组件监听待审核队列是否有待审核任务,当监听到待审核队列有待审核任务时,从队头取出待审核任务,取出后从线程池取出空闲的线程执行待审核任务,任务管理子单元更改审核任务状态为审核中,事后审核引擎根据审核任务的审核要求,从编译后的业务规则库提取本次审核涉及的业务规则包;基于提取的业务规则包,创建审核会话,根据任务号从内存缓存中提取业务JavaBean对象,将业务JavaBean对象加载到审核会话中,执行审核会话;审核会话结束后,审核结果绑定任务号,保存到内存缓存,更改审核任务状态为待组装,将审核任务挂载到待组装队列,线程结束并将线程返还线程池;

(2)组装组件监听待组装队列是否有待组装的任务,当监听到待组装队列有待组装任务,从队头取出待组装任务,取出后从线程池取出空闲的线程执行待组装任务,更改审核任务状态为组装中,根据任务号从内存缓存中提取出审核结果,按返回结果标准格式组装审核结果,组装完成后,绑定任务号,将组装结果保存到内存缓存,更改审核任务状态为待传回,将审核任务挂载到待传回队列,线程结束并将线程返还线程池;

(3)结果传回组件监听待传回队列是否有待传回任务,当监听到待传回队列有待传回任务,从队头取出待传回任务,取出后从线程池取出空闲的线程执行待传回任务,更改审核任务状态为传回中,根据任务号从内存缓存中提取组装结果,事后审核数据接口根据审核任务绑定的请求方地址,将组装结果加密压缩,发送给请求方,发送成功后,更改审核任务状态为待备份,将审核任务挂载到待备份队列,线程结束并将线程返还线程池;

(4)备份组件监听待备份队列是否有待备份任务,当监听到待备份队列有待备份任务,从队头取出待备份任务,取出后从线程池取出空闲的线程执行待备份任务,更改审核任务状态为备份中,将内存缓存中和该审核任务有关的所有数据持久化,保存到数据库,保存完成后,清除内存缓存中该审核任务的所有数据,降低内存缓存压力,更改审核任务状态为审核成功,线程结束并将线程返还线程池。

本发明的有益效果是:

(1)实现平台审核领域通用化,审核领域不局限于特定领域(财务报销、行政审批等),审核平台运行时的审核领域,是用户从项目库中选择的一个实例化项目涉及的领域,因为项目库可以包含多个领域的实例化项目,因此本审核平台方案支持多个审核领域,实现了审核领域通用化。

(2)业务数据无关性,审核平台开发时不关心实际处理的业务数据,解决现有技术在开发时已经默认设置需要处理的业务数据结构,部署后只能解析与默认设置的业务数据结构相对应的业务数据,突出审核平台处理业务数据范围的局限性,导致这种审核平台存在缺陷的问题。

(3)业务审核逻辑无关性,审核平台部署时不关心实际处理的业务审核逻辑,解决现有技术需要在开发时确定具体的业务审核逻辑,并在开发过程中固化在代码里,大大降低了系统的扩展性和灵活性的问题。

(4)支持不同的审核应用场景,本审核平台支持事中审核和事后审核两种审核方式。业务审核方式根据实时性、响应速度和数据量的不同审核要求,相应处理方式也应不同。

附图说明

图1为审核平台模块层级结构示意图;

图2为项目构建模块基于B/S架构的示意图;

图3为实例化项目示意图;

图4为项目库结构及审核平台实现方案示意图;

图5为业务规则库单元示意图;

图6为规则流的业务流程图组织结构图;

图7为事中审核流程图;

图8为事后审核流程图。

具体实施方式

下面结合附图进一步详细描述本发明的技术方案:

实施例1的审核平台由项目构建模块和智能审核模块两部分构成,其中,项目构建模块实现审核领域通用化,为智能审核执行审核任务提供支持;智能审核模块实现业务数据审核,提供可选的审核应用场景。本实施例的模块层级结构如图1所示。

如图2所示,在本实施例中,项目构建模块是基于B/S架构,用户通过终端浏览器登录智能审核平台,管理项目库;采用该实施例的方式,使得用户可以快速管理项目库。在另外一个实施例中,项目构建模块是基于C/S架构,用户通过终端安装对应客户端后登录智能审核平台,管理项目库。

项目构建实现平台审核领域通用化,审核领域不局限于特定领域(财务报销、行政审批等),审核平台运行时的审核领域,是用户从项目库中选择的一个实例化项目涉及的领域,因为项目库可以包含多个领域的实例化项目,因此本审核平台方案支持多个审核领域,实现了审核领域通用化。

项目构建模块负责管理项目库,如图4所示,项目库由零或多个实例化项目组成。

如图3所示,实例化项目由业务数据单元、业务数据库单元、业务JavaBean单元和业务规则库单元组成。具体地:

业务数据单元管理业务数据结构。其中,业务数据结构由数据表信息和字段信息组成,为解析审核请求方上传JSON数据包提供解析方案,为业务数据库单元、业务JavaBean单元和业务规则库单元管理提供支持。

业务数据库单元基于业务数据结构,管理业务数据库,为持久化审核数据提供物理存储支持。

业务JavaBean单元基于业务数据结构,管理业务JavaBean集。当审核请求到达时,为审核数据转换为实例化业务JavaBean对象提供支持。通过这种转换操作,审核平台可以操作审核数据,完成审核过程中的数据处理操作。

业务规则库单元将实例化项目的业务审核逻辑转换为Drools规则引擎能够识别的规则和规则流。当审核平台进行业务数据审核时,会依照用户定义的规则或规则流对审核数据进行审核。

在本实施例中,对项目库管理包括实例化项目添加、修改、查看和删除。

具体地,对于实例化项目添加:

在本实施例中,首先在实例化项目添加模板指导下,添加项目名、项目编号、项目介绍、业务数据库账号和密码等基本信息。

其中,项目编号作为审核平台区分实例化项目标识,由英文、数字和下划线组成,且第一个位置为英文;业务数据库账号和密码,在提交添加申请后,在数据库创建对应的数据库账号,创建的数据库账号作为实例化项目的业务数据库,存储实例化项目的业务数据。

当实例化项目添加成功后,进入实例化项目管理。实例化项目管理包括业务数据模块、业务数据库模块、业务JavaBean模块和业务规则模块。

对于添加业务数据结构,需要分别对数据表信息和字段信息进行添加:

在数据表信息添加模板指导下,添加数据表信息,数据表信息包括数据表名、数据表编号、数据表介绍和生成标志,其中:

数据表名为中文,为该数据表的中文名;

数据表介绍为中文,详细介绍该数据表;

生成标志表示该数据表信息是否生成对应业务JavaBean,是否在数据库中生成对应业务数据表;

数据表编号由英文、数字和下划线组成,且第一个位置为英文,作为业务数据表的表名和业务JavaBean的类名。

在数据表信息添加完成后,在字段信息添加模板指导下,添加该业务数据结构的所有字段信息,字段信息包括字段名、字段描述、字段编号、字段数据类型和大小、主键标志、可空标识、缺省值和关心标识,其中:

字段名为中文,为该字段的中文名;

字段描述为中文,详细介绍该字段;

字段编号作为业务数据表的字段名和业务JavaBean的类成员变量名,由英文、数字和下划线组成,且第一个位置为英文;

字段数据类型和大小对应数据库的字段数据类型和大小,比如varchar2(40)、number(10)和number(8,2)等,作为业务数据表该字段的数据类型和大小;根据与Java数据类型对应关系,作为业务JavaBean中该类成员变量的数据类型;

主键标志表示该字段在业务数据表中是否为主键;

可空标识表示该字段在业务数据表中是否可以为空;

缺省值表示该字段为空时的缺省值;

关心标识表示该字段是否为关心数据,在业务审核时,当该数据表数据触发了业务规则,需要将为关心数据的字段数据拼接在审核结果,返回给审核请求方。

在本实施例中,当业务数据结构的所有字段信息添加完成后,业务数据模块为该业务数据结构添加任务编号字段和任务数据索引字段,其中:

任务编号字段记录该条数据属于哪个审核任务,将数据以任务编号进行聚类区分;

任务数据索引字段标识该条数据是审核任务的哪一条业务数据,便于区分定位审核任务的业务数据。

任务编号字段和任务数据索引字段对于用户不可见,为审核平台内部操作所需,每个业务数据结构添加时都会自动生成这两个字段。

完成任务编号字段和任务数据索引字段自动生成后,业务数据模块会将该业务数据结构的数据表信息和字段信息进行关联,通过对每个字段信息绑定数据表编号,将该业务数据结构的数据表信息和字段信息关联起来。

经过上述一系列操作后,业务数据结构添加完成。

在添加业务数据结构过程中,可能存在数据表信息和字段信息的修改和删除。在没有生成对应业务数据表和业务JavaBean的条件下,实现流程如信息系统的修改和删除流程。

实例化项目可能包括多个业务数据结构,每个业务数据结构的添加流程如上所述。

在完成业务数据结构构建的前提下,业务数据库模块、业务JavaBean集模块和业务规则库模块的构建顺序没有关联,任意顺序进行。

在本实施例中,在业务数据结构成功添加前提下,业务数据库模块根据该业务数据结构的数据表编号和与该数据表编号绑定的字段信息,其中字段信息包括字段编号、字段数据类型和大小、主键标志、可空标识、缺省值,构造创建数据表SQL语句。构成完成后,在实例化项目业务数据库中执行构造的SQL语句,完成业务数据表创建,更新该业务数据结构数据表信息的生成标志,表明业务数据表已生成。

业务数据库模块将实例化项目的所有业务数据结构一一生成对应的业务数据表,构建业务数据库。

在本实施例中,在业务数据结构成功添加前提下,业务JavaBean模块根据该业务数据结构的数据表编号和与该数据表编号绑定的字段信息,其中字段信息包括字段编号、字段数据类型和大小,构造对应业务JavaBean的java文件。

构造方案为:数据表编号经过驼峰命名法处理后,将首字母大写,作为类名。字段编号经过驼峰命名法处理后,作为类成员变量名,根据字段数据类型和大小确定类成员变量的数据类型,比如number(4)为Integer,number(10)为Long,varchar2为String等。

完成构造类成员变量后,为每个类成员变量构造对应的get和set存取方法。如类成员变量 userName 的存取方法为 setUserName和getUserName。

业务JavaBean的java文件构造完成后,使用java语言编程编译器javac将java文件编译生成class文件,更新该业务数据结构数据表信息的生成标志,表明业务JavaBean已生成。审核平台启动时将生成的class文件加载到JVM,可以将上传的审核数据转换为实例化JavaBean对象,使平台能够在JVM中操作审核数据,同时审核数据JavaBean对象能插入审核会话中,作为审核引擎Work Memory中fact对象,去匹配业务规则进行审核。

业务JavaBean模块将实例化项目的所有业务数据结构一一生成对应的业务JavaBean,构建业务JavaBean集。

在本实施例中,完成实例化项目的业务数据结构添加后,添加业务规则库。

如图5所示,基于Drools规则引擎的业务规则分为规则和规则流。

其中,规则的结构如下:

rule "name" --规则名

attributes --属性部分

when

LHS --条件部分

then RHS --结果部分

end

规则通常包括三个部分: 属性部分(attribute)、条件部分(LHS)和结果部分(RHS)。

属性部分(attribute): 定义当前规则执行的一些属性等,比如是否可被重复执行、过期时间、生效时间等。

条件部分(LHS): 定义当前规则的条件,条件可以是单个, 也可以有多个。业务数据结构为条件部分构建提供支持。

结果部分(RHS): 定义满足当前条件部分后执行的操作。业务数据结构为结果部分构建提供支持。

如图6所示,规则流基于业务流程图实现。业务流程图描述了一系列需要执行的审核业务的顺序,它由规则、条件分支和分支聚合三部分组成。

业务规则库模块负责管理业务规则库,包括业务规则的添加、修改、查看和删除。

在本实施例中,业务规则的添加/修改/查看/删除:基于Web浏览器方式,用户在业务规则添加模板指导下,添加/修改/查看/删除规则或者规则流,提交添加/修改/查看/删除后,审核平台在规则库中生成业务规则。

完成业务数据结构、业务数据库、业务JavaBean集和业务规则库添加后,实例化项目添加流程完成。

在本实施例中,对于实例化项目修改:

在实例化项目修改模板指导下,可以修改项目名和项目介绍,项目编号、业务数据库账号和密码不能修改。

通过业务数据模块修改业务数据结构,其中包括数据表信息修改和字段信息修改。

数据表信息的数据表名和数据表介绍可以修改,数据表编号和生成标志不能修改。

字段信息的字段名、字段描述和关心标识可以修改,不影响业务数据库和业务JavaBean集。

字段信息的字段编号不能修改,字段数据类型和大小、主键标志、可空标识和缺省值可以修改。

当字段数据类型和大小被修改时,会触发业务数据库模块修改业务数据库和业务JavaBean模块修改业务JavaBean集。

当主键标志、可空标识和缺省值被修改时,会触发业务数据库模块修改业务数据库。

对于字段数据类型和大小、可空标识和缺省值被修改的情况,业务数据库模块根据绑定的数据表编号和字段编号,获取最新的字段数据类型和大小、可空标识和缺省值,然后构造修改数据库字段SQL语句,在实例化项目业务数据库执行构造的SQL语句,完成对应业务数据表修改。

对于主键标志被修改的情况,业务数据库模块根据绑定的数据表编号遍历其绑定的字段信息,查询出所有为主键的字段编号,构造创建主键SQL语句,在实例化项目业务数据库先执行删除已有主键操作,再执行构造的SQL语句,完成对应业务数据表主键修改。

对于字段数据类型和大小被修改的情况,业务JavaBean模块根据绑定的数据表编号和与该数据表编号绑定的字段信息,其中字段信息包括字段编号、字段数据类型和大小,构造对应业务JavaBean的java文件,构造方案如上文。java文件构造完成后,覆盖替换已有的java文件,使用java语言编程编译器javac将新的java文件编译生成新的class文件,覆盖替换已有的class文件。

业务规则库可以通过业务规则模块修改。

在本实施例中,对于实例化项目修改:

发起实例化项目删除后,审核平台会把所有和该项目有关的数据删除,包括项目信息、业务数据结构、业务规则库、业务JavaBean集和业务数据库等。注销业务数据库账号。

项目构建的核心操作如上所述。

平台审核领域通用化实现方案如图4所示,审核平台启动时根据用户配置信息,从项目库中选择一个实例化项目部署启动。

智能审核有事中审核和事后审核两种审核方式。

事中审核适用于实时性要求高、响应速度快、数据量小的审核任务,由第一审核数据接口、第一任务管理和事中审核引擎组成。其中:第一审核数据接口负责管理审核平台和审核请求方之间的数据通信,包括监听审核请求、解析审核请求和审核结果传回等;第一任务管理负责维护任务表、创建审核任务、更改任务状态和结束审核任务等,所有审核任务信息记录在任务表中,便于审核平台管理审核任务;事中审核引擎负责处理事中审核,包括业务数据审核、审核结果组装和审核任务持久化。

事中审核引擎包括业务数据审核组件、审核结果组装组件和审核任务持久化组件。其中,业务数据审核组件审核业务数据;审核结果组装组件按返回结果标准格式组装审核结果;核任务持久化组件将审核任务信息、业务数据和审核结果等持久化到物理数据库。

在本实施例中,事中审核的审核流程是一个非流水线方式,线性执行,同步过程。事中审核流程如图7所示:

S11:审核请求方将验证信息、审核要求和业务数据封装成JSON数据,然后加密压缩,设置为接口输入数据,调用事中审核接口发起请求,审核请求通过Internet传输到审核平台。

S12:第一审核数据接口捕获到审核请求,将上传数据解压解密,解析出验证信息,将验证信息与审核服务注册信息进行对比验证:如果验证通过,进入步骤S13;如果验证不通过,第一审核数据接口返回审核服务受限提示信息,并结束。

S13:第一审核数据接口解析审核要求:如果审核要求解析成功,第一任务管理创建审核任务,初始化审核任务,绑定请求方信息,设置审核要求,并进入步骤S14;如果审核要求解析不成功,第一审核数据接口将错误信息返回请求方。

S14:第一审核数据接口基于业务数据结构解析业务数据,如果业务数据解析成功,数据接口将业务数据转换为实例化业务JavaBean对象,转入事中审核引擎进行业务审核即步骤S15;反之第一任务管理注销审核任务,第一审核数据接口将错误信息返回请求方;

S15:事中审核引擎根据审核任务的审核要求,从编译后的业务规则库提取本次审核涉及的业务规则包。基于提取的业务规则包,创建审核会话,将业务数据JavaBean对象加载到审核会话中,执行审核会话。

S16:审核会话结束后,按返回结果标准格式组装审核结果,组装完成后,第一审核数据接口根据审核任务绑定的请求方的地址,将组装结果加密压缩,发送给审核请求方。发送成功后,将审核相关数据和审核任务信息备份到数据库,实现审核任务持久化,第一任务管理更改任务审核状态为审核成功,审核线程结束并将审核线程返还线程池,整个事中审核完成。

事后审核适用于实时性要求低、响应速度较快、数据量大的审核任务,由第二审核数据接口、第二任务管理和事后审核引擎组成。

其中:第二审核数据接口负责管理审核平台和审核请求方之间的数据通信,包括监听审核请求、解析审核请求和审核结果传回等;第二任务管理负责维护任务表、创建审核任务、更改任务状态和结束审核任务等,所有审核任务信息记录在任务表中,便于审核平台管理审核任务;事中审核引擎负责处理事中审核,包括业务数据审核、审核结果组装和审核任务持久化。

事后审核引擎包括业务数据审核组件、审核结果组装组件、结果传回组件和审核任务持久化组件。其中,业务数据审核组件审核业务数据;审核结果组装组件按返回结果标准格式组装审核结果;结果传回组件基于第二审核数据接口,将组装的审核结果传回审核请求方;任务持久化组件将审核任务信息、业务数据和审核结果等持久化到物理数据库。

在本实施例中,事后审核的审核流程是一个流水线方式,并行执行,异步过程。具体流程如图8所示:

S201:审核请求方将验证信息、审核要求和业务数据封装成JSON数据,加密压缩,设置为接口输入数据,调用事后审核接口发起请求,审核请求通过Internet传输到审核平台。

S202:第二审核数据接口模块捕获到审核请求,将上传数据解压解密,解析出验证信息,将验证信息与审核服务注册信息进行对比验证:验证通过,则进入步骤S203;否则,验证不通过,数据接口返回访问审核服务受限提示信息;

S203:第二审核数据接口解析审核要求:如果审核要求解析成功,任务管理创建审核任务,初始化审核任务,绑定请求方信息,设置审核要求,设置任务状态为审核数据待解析,并进入步骤S204;反之数据接口将错误信息返回给请求方,线程结束并将线程返还线程池。

S204:第二审核数据接口基于业务数据结构解析业务数据:如果解析业务数据成功,第二审核数据接口将业务数据转换为业务JavaBean对象,业务JavaBean对象绑定审核任务号,保存到内存缓存,将审核任务挂载到待审核队列,更改任务状态为待审核,转入事后审核引擎进行业务审核,返回审核任务号给审核请求方(便于审核请求方查看、管理审核任务进程),线程结束并将线程返还线程池,并进入步骤S205;反之,更改任务状态为审核数据解析失败,将错误信息返回给请求方,线程结束并将线程返还线程池。

S205:事后审核引擎的业务数据审核组件、审核结果组装组件、结果传回组件和审核任务持久化组件分别对对应队列进行处理:

(1)业务数据审核组件监听待审核队列是否有待审核任务,当监听到待审核队列有待审核任务时,从队头取出待审核任务,取出后从线程池取出空闲的线程执行待审核任务,第二任务管理更改审核任务状态为审核中,事后审核引擎根据审核任务的审核要求,从编译后的业务规则库提取本次审核涉及的业务规则包。基于提取的业务规则包,创建审核会话,根据任务号从内存缓存中提取业务JavaBean对象,将业务JavaBean对象加载到审核会话中,执行审核会话。审核会话结束后,审核结果绑定任务号,保存到内存缓存,更改审核任务状态为待组装,将审核任务挂载到待组装队列,线程结束并将线程返还线程池。

(2)审核结果组装组件监听待组装队列是否有待组装的任务,当监听到待组装队列有待组装任务,从队头取出待组装任务,取出后从线程池取出空闲的线程执行待组装任务,更改审核任务状态为组装中,根据任务号从内存缓存中提取出审核结果,按返回结果标准格式组装审核结果,组装完成后,绑定任务号,将组装结果保存到内存缓存,更改审核任务状态为待传回,将审核任务挂载到待传回队列,线程结束并将线程返还线程池。

(3)结果传回组件监听待传回队列是否有待传回任务,当监听到待传回队列有待传回任务,从队头取出待传回任务,取出后从线程池取出空闲的线程执行待传回任务,更改审核任务状态为传回中,根据任务号从内存缓存中提取组装结果,数据接口模块根据审核任务绑定的请求方地址,将组装结果加密压缩,发送给请求方,发送成功后,更改审核任务状态为待备份,将审核任务挂载到待备份队列,线程结束并将线程返还线程池。

(4)审核任务持久化组件监听待备份队列是否有待备份任务,当监听到待备份队列有待备份任务,从队头取出待备份任务,取出后从线程池取出空闲的线程执行待备份任务,更改审核任务状态为备份中,将内存缓存中和该审核任务有关的所有数据持久化,保存到数据库,保存完成后,清除内存缓存中该审核任务的所有数据,降低内存缓存压力,更改审核任务状态为审核成功,线程结束并将线程返还线程池,整个事后审核完成。

医疗保险报销审核,比如病人一次住院产生的所有费用报销审核,首先审核数据量大,允许秒级审核时间,对实时性要求不高,可以采用事后审核方式执行审核。业务办理审核,比如在柜台办理业务申请时,首先需要审核业务申请者是否具有办理该业务的资格,然后才能进入业务办理流程,这种实时性高、响应速度快、数据量小的审核应用场景,可以采用事中审核方式执行审核。

当前第1页1 2 3 
网友询问留言 已有0条留言
  • 还没有人留言评论。精彩留言会获得点赞!
1