CN115016978A - 数据校验方法及装置、计算机存储介质、电子设备 - Google Patents
数据校验方法及装置、计算机存储介质、电子设备 Download PDFInfo
- Publication number
- CN115016978A CN115016978A CN202210381797.9A CN202210381797A CN115016978A CN 115016978 A CN115016978 A CN 115016978A CN 202210381797 A CN202210381797 A CN 202210381797A CN 115016978 A CN115016978 A CN 115016978A
- Authority
- CN
- China
- Prior art keywords
- verification
- data
- target data
- rule
- configuration file
- Prior art date
- Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
- Pending
Links
Images
Classifications
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F11/00—Error detection; Error correction; Monitoring
- G06F11/07—Responding to the occurrence of a fault, e.g. fault tolerance
- G06F11/08—Error detection or correction by redundancy in data representation, e.g. by using checking codes
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F16/00—Information retrieval; Database structures therefor; File system structures therefor
- G06F16/20—Information retrieval; Database structures therefor; File system structures therefor of structured data, e.g. relational data
- G06F16/28—Databases characterised by their database models, e.g. relational or object models
- G06F16/284—Relational databases
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F9/00—Arrangements for program control, e.g. control units
- G06F9/06—Arrangements for program control, e.g. control units using stored programs, i.e. using an internal store of processing equipment to receive or retain programs
- G06F9/44—Arrangements for executing specific programs
- G06F9/451—Execution arrangements for user interfaces
Landscapes
- Engineering & Computer Science (AREA)
- Theoretical Computer Science (AREA)
- Software Systems (AREA)
- Physics & Mathematics (AREA)
- General Engineering & Computer Science (AREA)
- General Physics & Mathematics (AREA)
- Databases & Information Systems (AREA)
- Human Computer Interaction (AREA)
- Data Mining & Analysis (AREA)
- Quality & Reliability (AREA)
- Information Retrieval, Db Structures And Fs Structures Therefor (AREA)
Abstract
本公开涉及计算机技术领域,提供了一种数据校验方法、数据校验装置、计算机存储介质、电子设备,其中,数据校验方法包括:响应于页面获取请求,将预先存储的可视化页面及校验规则发送至前端,以使所述前端展示所述可视化页面,并基于所述校验规则对用户通过所述可视化页面输入的数据进行校验;在接收到所述前端校验通过的目标数据之后,利用校验配置文件对所述目标数据进行再次校验;所述校验配置文件基于所述校验规则生成;响应于所述再次校验通过,将所述目标数据导入数据库。本公开能够保证前后端服务器校验规则的复用,保证前后端校验结果的一致性,提高入库数据的准确度。
Description
技术领域
本公开涉及计算机技术领域,特别涉及一种数据校验方法、数据校验装置、计算机存储介质及电子设备。
背景技术
通常情况下,对于一个表单的验证分两个步骤,首先在用户录入完一条数据后实时进行前端校验并展示校验结果,方便用户快捷的录入准确的数据,其次,在表单提交到后端服务器以后,后端服务器需要对数据再进行一次校验,以确保数据的准确性。
目前,前后端的校验规则一般是分开编写且独立的,例如,前端使用JS(JavaScript)方法进行校验,后端服务器采用具体的后端服务器语言进行校验,从而,当新建或修改某个校验规则时,必须同时对前后端的代码进行修改,业务复杂度较高。
鉴于此,本领域亟需开发一种新的数据校验方法及装置。
需要说明的是,上述背景技术部分公开的信息仅用于加强对本公开的背景的理解。
发明内容
本公开的目的在于提供一种数据校验方法、数据校验装置、计算机存储介质及电子设备,进而至少在一定程度上克服了相关前后端独立校验所导致的校验规则更新复杂度高的问题。
本公开的其他特性和优点将通过下面的详细描述变得显然,或部分地通过本公开的实践而习得。
根据本公开的第一方面,提供一种数据校验方法,包括:响应于页面获取请求,将预先存储的可视化页面及校验规则发送至前端,以使所述前端展示所述可视化页面,并基于所述校验规则对用户通过所述可视化页面输入的数据进行校验;在接收到所述前端校验通过的目标数据之后,利用校验配置文件对所述目标数据进行再次校验;所述校验配置文件基于所述校验规则生成;响应于所述再次校验通过,将所述目标数据导入数据库。
在本公开的示例性实施例中,所述校验配置文件通过以下方式得到:接收通过所述可视化页面配置的每个字段的校验规则;将每个字段对应的校验规则进行聚合,得到每个字段对应的校验配置;将多个字段对应的校验配置进行聚合,得到所述校验配置文件。
在本公开的示例性实施例中,所述校验规则为JSON格式;所述校验配置文件为JSONSchema格式。
在本公开的示例性实施例中,利用校验配置文件对所述目标数据进行再次校验,包括:将所述目标数据转换为JSON格式;遍历所述目标数据的每个字段,并从所述校验配置文件中匹配所述每个字段对应的目标校验规则;利用各所述目标校验规则对各所述字段进行再次校验,获得所述每个字段的校验结果;基于所述多个字段的校验结果,确定所述目标数据的校验结果。
在本公开的示例性实施例中,所述基于所述多个字段的校验结果,确定所述目标数据的校验结果,包括:响应于所述多个字段中任一字段校验失败,确定所述目标数据校验失败。
在本公开的示例性实施例中,所述基于所述多个字段的校验结果,确定所述目标数据的校验结果,包括:响应于所述多个字段均校验通过,确定所述目标数据校验通过。
在本公开的示例性实施例中,响应于所述再次校验通过,将所述目标数据导入数据库,包括:响应于所述再次校验通过,对所述目标数据进行加密处理;将加密处理之后的所述目标数据导入数据库。
根据本公开的第二方面,提供一种数据校验装置,包括:前端校验模块,用于响应于页面获取请求,将预先存储的可视化页面及校验规则发送至前端,以使所述前端展示所述可视化页面,并基于所述校验规则对用户通过所述可视化页面输入的数据进行校验;后端校验模块,用于在接收到所述前端校验通过的目标数据之后,利用校验配置文件对所述目标数据进行再次校验;所述校验配置文件基于所述校验规则生成;数据入库模块,用于响应于所述再次校验通过,将所述目标数据导入数据库。
根据本公开的第三方面,提供一种计算机存储介质,其上存储有计算机程序,所述计算机程序被处理器执行时实现上述第一方面所述的数据校验方法。
根据本公开的第四方面,提供一种电子设备,包括:处理器;以及存储器,用于存储所述处理器的可执行指令;其中,所述处理器配置为经由执行所述可执行指令来执行上述第一方面所述的数据校验方法。
由上述技术方案可知,本公开示例性实施例中的数据校验方法、数据校验装置、计算机存储介质及电子设备至少具备以下优点和积极效果:
在本公开的一些实施例所提供的技术方案中,响应于页面获取请求,将预先存储的可视化页面及校验规则发送至前端,以使所述前端展示所述可视化页面,并基于所述校验规则对用户通过所述可视化页面输入的数据进行校验,在接收到所述前端校验通过的目标数据之后,利用校验配置文件对所述目标数据进行再次校验;所述校验配置文件基于所述校验规则生成;响应于所述再次校验通过,将所述目标数据导入数据库。一方面,能够保证校验规则的复用,解决相关技术中前后端服务器分开校验所导致的校验结果不一致、容易导致错误数据入库的技术问题,保证前后端服务器校验结果的一致性,提高入库数据的准确度。另一方面,在需要增加新的校验规则时,本公开仅需在可视化页面中进行简单配置即可实现前后端服务器校验规则的更新,无需开发人员分别在前端和后端服务器编写代码,减少了开发人员的代码编写量,降低了规则更新复杂度,提高了数据校验效率。
本公开应当理解的是,以上的一般描述和后文的细节描述仅是示例性和解释性的,并不能限制本公开。
附图说明
此处的附图被并入说明书中并构成本说明书的一部分,示出了符合本公开的实施例,并与说明书一起用于解释本公开的原理。显而易见地,下面描述中的附图仅仅是本公开的一些实施例,对于本领域普通技术人员来讲,在不付出创造性劳动的前提下,还可以根据这些附图获得其他的附图。
图1示出本公开实施例中数据校验方法的流程示意图;
图2示出本公开实施例中预先创建可视化页面及配置校验规则的流程示意图;
图3示出本公开实施例中根据校验配置文件对目标数据进行再次校验的流程示意图;
图4示出本公开实施例中确定目标数据的校验结果的流程示意图;
图5示出本公开实施例中数据校验方法的整体流程示意图;
图6示出本公开示例性实施例中数据校验装置的结构示意图;
图7示出本公开示例性实施例中电子设备的结构示意图。
具体实施方式
现在将参考附图更全面地描述示例实施方式。然而,示例实施方式能够以多种形式实施,且不应被理解为限于在此阐述的范例;相反,提供这些实施方式使得本公开将更加全面和完整,并将示例实施方式的构思全面地传达给本领域的技术人员。所描述的特征、结构或特性可以以任何合适的方式结合在一个或更多实施方式中。在下面的描述中,提供许多具体细节从而给出对本公开的实施方式的充分理解。然而,本领域技术人员将意识到,可以实践本公开的技术方案而省略所述特定细节中的一个或更多,或者可以采用其它的方法、组元、装置、步骤等。在其它情况下,不详细示出或描述公知技术方案以避免喧宾夺主而使得本公开的各方面变得模糊。
本说明书中使用用语“一个”、“一”、“该”和“所述”用以表示存在一个或多个要素/组成部分/等;用语“包括”和“具有”用以表示开放式的包括在内的意思并且是指除了列出的要素/组成部分/等之外还可存在另外的要素/组成部分/等;用语“第一”和“第二”等仅作为标记使用,不是对其对象的数量限制。
此外,附图仅为本公开的示意性图解,并非一定是按比例绘制。图中相同的附图标记表示相同或类似的部分,因而将省略对它们的重复描述。附图中所示的一些方框图是功能实体,不一定必须与物理或逻辑上独立的实体相对应。
目前,软件研发中使用较多的前后端校验解决方案为前后端独立校验,即前端采用JS(JavaScript)方式进行校验,后端服务器采用具体的后端服务器语言(例如:Java)进行校验,二者之间无关联性。
从而,上述方案具有以下缺陷:
第一,无法保证前后端校验结果的一致性,容易导致错误数据入库,影响业务开展;
第二,在增加新的校验规则时,需要对前后端分别进行功能开发,工作量大,效率低。
在本公开的实施例中,首先提供了一种数据校验方法,至少在一定程度上克服相关前后端独立校验所导致的校验规则更新复杂度高的缺陷。
图1示出本公开实施例中数据校验方法的流程示意图,该数据校验方法的执行主体可以是对数据进行校验的后端服务器。
参考图1,根据本公开的一个实施例的数据校验方法包括以下步骤:
步骤S110,响应于页面获取请求,将预先存储的可视化页面及校验规则发送至前端,以使前端展示可视化页面,并基于校验规则对用户通过可视化页面输入的数据进行校验;
步骤S120,在接收到前端校验通过的目标数据之后,利用校验配置文件对目标数据进行再次校验;校验配置文件为根据校验规则生成的;
步骤S130,响应于再次校验通过,将目标数据导入数据库。
在图1所示实施例所提供的技术方案中,响应于页面获取请求,将预先存储的可视化页面及校验规则发送至前端,以使前端展示可视化页面,并基于校验规则对用户通过可视化页面输入的数据进行校验,在接收到前端校验通过的目标数据之后,利用校验配置文件对目标数据进行再次校验;校验配置文件为根据校验规则生成的;响应于再次校验通过,将目标数据导入数据库。一方面,能够保证校验规则的复用,解决相关技术中前后端服务器分开校验所导致的校验结果不一致、容易导致错误数据入库的技术问题,保证前后端服务器校验结果的一致性,提高入库数据的准确度。另一方面,在需要增加新的校验规则时,本公开仅需在可视化页面中进行简单配置即可实现前后端服务器校验规则的更新,无需开发人员分别在前端和后端服务器编写代码,减少了开发人员的代码编写量,降低了规则更新复杂度,提高了数据校验效率。
以下对图1中的各个步骤的具体实现过程进行详细阐述:
在步骤S110之前,需要说明的是,开发人员可以预先在前端创建一可视化界面,该可视化页面的作用可以是:开发人员配置、快速新增及修改每个字段的校验规则,在将其输出给用户时,用户可以在可视化页面上输入数据。
具体的,可以预先采用基于VUE框架的页面编辑器在前端创建一可视化页面,在创建可视化页面时,可以根据业务需要,自行设置不同样式的页面组件(例如:图标、按钮等),以提升可视化页面的趣味性。其中,VUE是一套用于构建用户界面的渐进式JavaScript框架。与其它大型框架不同的是,Vue被设计为可以自底向上逐层应用。Vue的核心库只关注视图层,不仅易于上手,还便于与第三方库或既有项目整合。
在创建好可视化页面之后,可以梳理各个业务字段,并根据不同的业务字段所对应的校验需求,在上述可视化页面中配置每个业务字段对应的校验规则,示例性的,每个业务字段可以对应多个校验规则,可以根据实际情况自行设定,本公开对此不作特殊限定。
示例性的,以“税率”字段(是对征税对象的征收比例或征收额度)为例进行说明,其校验规则可以包括以下一个或多个:非空校验规则(即校验字段值是否为空值)、长度校验规则(即校验字段值的长度是否满足指定的长度区间)、数据类型校验规则(即校验字段值是否满足指定的数据类型,例如,整数或小数)、日期校验规则(即校验字段值是否为指定时间段内的有效数据,是否过期等)、正则表达式规则(即使用配置好的正则表达式验证字段值是否合法)、关联关系校验规则(即校验不同字段值之间的关联关系,例如:是否大于某一字段的字段值)等,均可以根据实际情况自行设定,本公开对此不作特殊限定。
在配置好各个字段对应的校验规则之后,可以将上述可视化页面和各个字段对应的校验规则以JSON格式进行提交,以将其保存至后端服务器中。其中,JSON(JavaScriptObject Notation,JS对象简谱)是一种轻量级的数据交换格式,它是基于ECMA Script的一个子集。JSON采用完全独立于语言的文本格式,但是也使用了类似于C语言的习惯,这些特性使得JSON成为理想的数据交换语言,便于人阅读和编写,同时也易于机器解析和生成,提升网络传输速率。
进而,后端服务器可以接收通过可视化页面配置的每个字段的校验规则,将每个字段对应的校验规则聚合在一起,得到每个字段对应的校验配置,再将多个字段对应的校验配置聚合在一起,得到一JSONSchema格式的校验配置文件。
具体的,后端服务器可以利用JsonSchema.net(是一个从JSON数据自动生成JSONSchema的工具)将JSON格式的校验规则转换为JSONSchema格式的校验配置文件,并将其存储在数据库(又称为数据管理系统,是处理的数据按照一定的方式储存在一起,能够让多个用户共享、尽可能减小冗余度的数据集合,简而言之可视为电子化的文件柜)或缓存(缓存是指可以进行高速数据交换的存储器,它先于内存与处理器交换数据,因此速率很快)中,以备后续校验过程中使用。
其中,JSONschema是一组特殊的JSON词汇,其本身也是JSON格式,一般使用JsonSchema来进行JSON数据格式验证,在数据提交到业务层次之前进行JSON格式的验证。
通过预先配置可视化页面,在后续业务变更的情况下(例如:需要增加新的校验规则,或,需要删除已创建的校验规则),开发人员可以直接在上述可视化页面中通过简单的交互操作新增或删除校验规则,在操作完成之后可以将其提交保存,进而,后端服务器可以将接收到的校验规则转换为JSONSchema格式的校验配置文件,并将其保存备用。
可见,相比现有技术中需要开发人员花费大量时间分别修改前端代码、后端服务器代码,并重启服务器才能实现校验规则更新的方案而言,本公开能够降低校验规则的更新成本,降低开发人员的代码编写量,提升校验规则的更新效率,降低开发成本。
示例性的,参考图2,图2示出本公开实施例中预先创建可视化页面及配置校验规则的流程示意图,包含步骤S201-步骤S208:
在步骤S201中,开始;
在步骤S202中,在前端创建可视化页面;
在步骤S203中,在可视化页面上配置每个业务字段的校验规则;
在步骤S204中,在前端提交保存;
在步骤S205中,后端服务器保存可视化页面并从中提取校验规则;
在步骤S206中,后端服务器解析校验规则,以将校验规则转换为校验配置文件;
在步骤S207中,后端服务器保存校验配置文件,以备后续校验过程使用;
在步骤S208中,结束。
接着参考图1,在步骤S110中,响应于页面获取请求,将预先存储的可视化页面及校验规则发送至前端,以使前端展示可视化页面,并基于校验规则对用户通过可视化页面输入的数据进行校验。
本步骤中,当用户需要输入表单数据时,可以通过前端向后端服务服务器发送页面获取请求,进而,后端服务器可以将预先存储的可视化页面和校验规则发送至前端,进而,VUE引擎可以对可视化页面进行渲染,以在前端显示上述可视化页面。
进而,用户可以手动在上述可视化页面中输入数据,在用户完成数据输入并点击提交按钮之后,前端可以利用上述校验规则对用户输入的数据进行校验。若前端校验失败,则可以将上述数据丢弃,并向用户返回验证失败的原因等,以便于用户对数据进行修改及再次提交。若前端校验通过,则可以将数据提交至后端服务器进行再次校验。
前端校验的目的在于确保用户交互操作的正确性,同时兼顾安全性。通过前端校验,可以筛除一些不合法的数据,便于用户快速纠正数据,并且减少服务器压力,节省流量,对用户友好。比如手机号码,邮箱号不合法,或者密码强度太弱,在前端校验可以不等后端服务器返回,直接提醒用户不合法,让用户及时知晓并更改,避免不必要的提交,再等待服务器返回错误信息。
在步骤S120中,在接收到前端校验通过的目标数据之后,利用校验配置文件对目标数据进行再次校验。
本步骤中,在获取到上述目标数据之后,后端服务器可以利用校验配置文件,对上述目标数据进行再次校验。具体的,参考图3,图3示出本公开实施例中根据校验配置文件对目标数据进行再次校验的流程示意图,包含步骤S301-步骤S304:
在步骤S301中,将目标数据转换为JSON格式。
本步骤中,可以先将上述目标数据转换为JSON格式。
在步骤S302中,遍历目标数据的每个字段,并从校验配置文件中匹配每个字段对应的目标校验规则。
本步骤中,鉴于不同的字段对应不同的校验规则,而校验配置文件是对校验规则进行聚合之后得到的文件,从而,校验配置文件中包含了多个校验规则。从而,可以遍历上述目标数据的每个字段,并从校验配置文件中查找每个字段对应的目标校验规则。
在步骤S303中,利用各目标校验规则对各字段进行再次校验,获得每个字段的校验结果。
本步骤中,可以利用各目标校验规则,对各字段依次进行再次校验,得到每个字段的校验结果,循环执行该步骤,直至获得上述多个字段的校验结果。
需要说明的是,若在校验配置文件中未查找到某一字段对应的校验规则,则可以省去对该字段的校验过程,默认其校验通过。
在步骤S304中,基于多个字段的校验结果,确定目标数据的校验结果。
本步骤中,参照图4,图4示出本公开实施例中确定目标数据的校验结果的流程示意图,包含步骤S401-步骤S402:
在步骤S401中,响应于多个字段中任一字段校验失败,确定目标数据校验失败。
本步骤中,当目标数据存在任意一个字段校验失败时,则可以确定该目标数据的校验结果为校验失败。
在步骤S402中,响应于多个字段均校验通过,确定目标数据校验通过。
本步骤中,当目标数据所对应的多个字段均校验通过时,则可以确定该目标数据的校验结果为校验通过。
接着参考图1,在步骤S130中,响应于再次校验通过,将目标数据导入数据库。
在本公开的示例性实施例中,在后端服务器对上述目标数据校验通过之后,可以将上述目标数据以Map数组的形式(key-value)保存至数据库中。
其中,Map(也称为字典、关联数组)是用于保存具有映射关系的数据,保存两组值,key和value,这两组值可以是任何应用类型的数据。其中,key指的是关键字,例如:元素的属性。value指的是键值,例如:元素的属性值。key-value分布式存储系统查询速度快、存放数据量大、支持高并发,适合通过主键进行查询。
在一种可选的实施方式中,在上述再次校验通过之后,还可以对上述目标数据进行加密,示例性的,可以采用摘要算法、对称加密算法或非对称加密算法对上述目标数据进行加密,并将加密之后的目标数据导入数据库,以保证数据安全性。
后端服务器校验的目的是保证安全性和业务逻辑正确性,确保数据未被劫持篡改。通过后端服务器校验可以防止接口被私自调用导致破坏数据库结构,避免通过非法方式(例如:直接模拟浏览器行为)向后端服务器传入脏数据的问题,保证最终入库数据的准确度。
参考图5,图5示出本公开实施例中数据校验方法的整体流程图,包含步骤S501-步骤S510:
在步骤S501中,开始;
在步骤S502中,前端发送页面获取请求(即触发操作),后端服务器获取预先存储的可视化页面及校验规则并返回至前端;
在步骤S503中,前端渲染并展示可视化页面;
在步骤S504中,用户在页面上输入数据;
在步骤S505中,前端对数据进行校验;
在步骤S506中,判断前端是否校验通过;
若校验通过,则进入步骤S507中,后端服务器对数据进行校验;否则,进入步骤S510中,结束;
在步骤S508中,判断后端服务器是否校验通过;
若校验通过,则进入步骤S509中,保存数据;否则,进入步骤S510中,结束。
基于以上技术方案,本公开不仅能够解决相关技术中前后端独立校验所导致的无法保证前后端校验结果的一致性、容易导致错误数据入库的技术问题,保证前后端校验结果的一致性,提高入库数据的准确度。另一方面,在需要增加新的校验规则时,无需对前后端都进行对应功能的开发,降低开发工作量,提升开发效率。
本公开还提供了一种数据校验装置,图6示出本公开示例性实施例中数据校验装置的结构示意图;如图6所示,数据校验装置600可以包括前端校验模块610、后端校验模块620和数据入库模块630。其中:
前端校验模块610,用于响应于页面获取请求,将预先存储的可视化页面及校验规则发送至前端,以使所述前端展示所述可视化页面,并基于所述校验规则对用户通过所述可视化页面输入的数据进行校验;
后端校验模块620,用于在接收到所述前端校验通过的目标数据之后,利用校验配置文件对所述目标数据进行再次校验;所述校验配置文件基于所述校验规则生成;
数据入库模块630,用于响应于所述再次校验通过,将所述目标数据导入数据库。
在本公开的示例性实施例中,所述校验配置文件通过以下方式得到:接收通过所述可视化页面配置的每个字段的校验规则;将每个字段对应的校验规则进行聚合,得到每个字段对应的校验配置;将多个字段对应的校验配置进行聚合,得到所述校验配置文件。
在本公开的示例性实施例中,所述校验规则为JSON格式;所述校验配置文件为JSONSchema格式。
在本公开的示例性实施例中,后端校验模块620,被配置为:
将所述目标数据转换为JSON格式;遍历所述目标数据的每个字段,并从所述校验配置文件中匹配所述每个字段对应的目标校验规则;利用各所述目标校验规则对各所述字段进行再次校验,获得所述每个字段的校验结果;基于所述多个字段的校验结果,确定所述目标数据的校验结果。
在本公开的示例性实施例中,后端校验模块620,被配置为:
响应于所述多个字段中任一字段校验失败,确定所述目标数据校验失败。
在本公开的示例性实施例中,后端校验模块620,被配置为:
响应于所述多个字段均校验通过,确定所述目标数据校验通过。
在本公开的示例性实施例中,数据入库模块630,被配置为:
响应于所述再次校验通过,对所述目标数据进行加密处理;将加密处理之后的所述目标数据导入数据库。
上述数据校验装置中各模块的具体细节已经在对应的数据校验方法中进行了详细的描述,因此此处不再赘述。
应当注意,尽管在上文详细描述中提及了用于动作执行的设备的若干模块或者单元,但是这种划分并非强制性的。实际上,根据本公开的实施方式,上文描述的两个或更多模块或者单元的特征和功能可以在一个模块或者单元中具体化。反之,上文描述的一个模块或者单元的特征和功能可以进一步划分为由多个模块或者单元来具体化。
此外,尽管在附图中以特定顺序描述了本公开中方法的各个步骤,但是,这并非要求或者暗示必须按照该特定顺序来执行这些步骤,或是必须执行全部所示的步骤才能实现期望的结果。附加的或备选的,可以省略某些步骤,将多个步骤合并为一个步骤执行,以及/或者将一个步骤分解为多个步骤执行等。
通过以上的实施方式的描述,本领域的技术人员易于理解,这里描述的示例实施方式可以通过软件实现,也可以通过软件结合必要的硬件的方式来实现。因此,根据本公开实施方式的技术方案可以以软件产品的形式体现出来,该软件产品可以存储在一个非易失性存储介质(可以是CD-ROM,U盘,移动硬盘等)中或网络上,包括若干指令以使得一台计算设备(可以是个人计算机、服务器、移动终端、或者网络设备等)执行根据本公开实施方式的方法。
本申请还提供了一种计算机可读存储介质,该计算机可读存储介质可以是上述实施例中描述的电子设备中所包含的;也可以是单独存在,而未装配入该电子设备中。
计算机可读存储介质例如可以是——但不限于——电、磁、光、电磁、红外线、或半导体的系统、装置或器件,或者任意以上的组合。计算机可读存储介质的更具体的例子可以包括但不限于:具有一个或多个导线的电连接、便携式计算机磁盘、硬盘、随机访问存储器(RAM)、只读存储器(ROM)、可擦式可编程只读存储器(EPROM或闪存)、光纤、便携式紧凑磁盘只读存储器(CD-ROM)、光存储器件、磁存储器件、或者上述的任意合适的组合。在本公开中,计算机可读存储介质可以是任何包含或存储程序的有形介质,该程序可以被指令执行系统、装置或者器件使用或者与其结合使用。
计算机可读存储介质可以发送、传播或者传输用于由指令执行系统、装置或者器件使用或者与其结合使用的程序。计算机可读存储介质上包含的程序代码可以用任何适当的介质传输,包括但不限于:无线、电线、光缆、RF等等,或者上述的任意合适的组合。
计算机可读存储介质承载有一个或者多个程序,当上述一个或者多个程序被一个该电子设备执行时,使得该电子设备实现如上述实施例中所述的方法。
此外,在本公开实施例中还提供了一种能够实现上述方法的电子设备。
所属技术领域的技术人员能够理解,本公开的各个方面可以实现为系统、方法或程序产品。因此,本公开的各个方面可以具体实现为以下形式,即:完全的硬件实施方式、完全的软件实施方式(包括固件、微代码等),或硬件和软件方面结合的实施方式,这里可以统称为“电路”、“模块”或“系统”。
下面参照图7来描述根据本公开的这种实施方式的电子设备700。图7显示的电子设备700仅仅是一个示例,不应对本公开实施例的功能和使用范围带来任何限制。
如图7所示,电子设备700以通用计算设备的形式表现。电子设备700的组件可以包括但不限于:上述至少一个处理单元710、上述至少一个存储单元720、连接不同系统组件(包括存储单元720和处理单元710)的总线730以及显示单元740。
其中,所述存储单元存储有程序代码,所述程序代码可以被所述处理单元710执行,使得所述处理单元710执行本说明书上述“示例性方法”部分中描述的根据本公开各种示例性实施方式的步骤。例如,所述处理单元710可以执行如图1中所示的:步骤S110,响应于页面获取请求,将预先存储的可视化页面及校验规则发送至前端,以使前端展示可视化页面,并基于校验规则对用户通过可视化页面输入的数据进行校验;步骤S120,在接收到前端校验通过的目标数据之后,利用校验配置文件对目标数据进行再次校验;校验配置文件为根据校验规则生成的;步骤S130,响应于再次校验通过,将目标数据导入数据库。
存储单元720可以包括易失性存储单元形式的可读介质,例如随机存取存储单元(RAM)7201和/或高速缓存存储单元7202,还可以进一步包括只读存储单元(ROM)7203。
存储单元720还可以包括具有一组(至少一个)程序模块7205的程序/实用工具7204,这样的程序模块7205包括但不限于:操作系统、一个或者多个应用程序、其它程序模块以及程序数据,这些示例中的每一个或某种组合中可能包括网络环境的实现。
总线730可以为表示几类总线结构中的一种或多种,包括存储单元总线或者存储单元控制器、外围总线、图形加速端口、处理单元或者使用多种总线结构中的任意总线结构的局域总线。
电子设备700也可以与一个或多个外部设备800(例如键盘、指向设备、蓝牙设备等)通信,还可与一个或者多个使得用户能与该电子设备700交互的设备通信,和/或与使得该电子设备700能与一个或多个其它计算设备进行通信的任何设备(例如路由器、调制解调器等等)通信。这种通信可以通过输入/输出(I/O)接口750进行。并且,电子设备700还可以通过网络适配器760与一个或者多个网络(例如局域网(LAN),广域网(WAN)和/或公共网络,例如因特网)通信。如图所示,网络适配器760通过总线730与电子设备700的其它模块通信。应当明白,尽管图中未示出,可以结合电子设备700使用其它硬件和/或软件模块,包括但不限于:微代码、设备驱动器、冗余处理单元、外部磁盘驱动阵列、RAID系统、磁带驱动器以及数据备份存储系统等。
本领域技术人员在考虑说明书及实践这里公开的发明后,将容易想到本公开的其他实施例。本申请旨在涵盖本公开的任何变型、用途或者适应性变化,这些变型、用途或者适应性变化遵循本公开的一般性原理并包括本公开未公开的本技术领域中的公知常识或惯用技术手段。说明书和实施例仅被视为示例性的,本公开的真正范围和精神由权利要求指出。
Claims (10)
1.一种数据校验方法,其特征在于,应用于后端服务器,包括:
响应于页面获取请求,将预先存储的可视化页面及校验规则发送至前端,以使所述前端展示所述可视化页面,并基于所述校验规则对用户通过所述可视化页面输入的数据进行校验;
在接收到所述前端校验通过的目标数据之后,利用校验配置文件对所述目标数据进行再次校验;所述校验配置文件基于所述校验规则生成;
响应于所述再次校验通过,将所述目标数据导入数据库。
2.根据权利要求1所述的方法,其特征在于,所述校验配置文件通过以下方式得到:
接收通过所述可视化页面配置的每个字段的校验规则;
将每个字段对应的校验规则进行聚合,得到每个字段对应的校验配置;
将多个字段对应的校验配置进行聚合,得到所述校验配置文件。
3.根据权利要求1所述的方法,其特征在于,所述校验规则为JSON格式;所述校验配置文件为JSONSchema格式。
4.根据权利要求1至3任意一项所述的方法,其特征在于,利用校验配置文件对所述目标数据进行再次校验,包括:
将所述目标数据转换为JSON格式;
遍历所述目标数据的每个字段,并从所述校验配置文件中匹配所述每个字段对应的目标校验规则;
利用各所述目标校验规则对各所述字段进行再次校验,获得所述每个字段的校验结果;
基于所述多个字段的校验结果,确定所述目标数据的校验结果。
5.根据权利要求4所述的方法,其特征在于,所述基于所述多个字段的校验结果,确定所述目标数据的校验结果,包括:
响应于所述多个字段中任一字段校验失败,确定所述目标数据校验失败。
6.根据权利要求4所述的方法,其特征在于,所述基于所述多个字段的校验结果,确定所述目标数据的校验结果,包括:
响应于所述多个字段均校验通过,确定所述目标数据校验通过。
7.根据权利要求1所述的方法,其特征在于,所述响应于所述再次校验通过,将所述目标数据导入数据库,包括:
响应于所述再次校验通过,对所述目标数据进行加密处理;
将加密处理之后的所述目标数据导入数据库。
8.一种数据校验装置,其特征在于,包括:
前端校验模块,用于响应于页面获取请求,将预先存储的可视化页面及校验规则发送至前端,以使所述前端展示所述可视化页面,并基于所述校验规则对用户通过所述可视化页面输入的数据进行校验;
后端校验模块,用于在接收到所述前端校验通过的目标数据之后,利用校验配置文件对所述目标数据进行再次校验;所述校验配置文件基于所述校验规则生成;
数据入库模块,用于响应于所述再次校验通过,将所述目标数据导入数据库。
9.一种计算机存储介质,其上存储有计算机程序,其特征在于,所述计算机程序被处理器执行时实现权利要求1~7中任意一项所述的数据校验方法。
10.一种电子设备,其特征在于,包括:
处理器;以及
存储器,用于存储所述处理器的可执行指令;
其中,所述处理器配置为经由执行所述可执行指令来执行权利要求1~7中任意一项所述的数据校验方法。
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN202210381797.9A CN115016978A (zh) | 2022-04-12 | 2022-04-12 | 数据校验方法及装置、计算机存储介质、电子设备 |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN202210381797.9A CN115016978A (zh) | 2022-04-12 | 2022-04-12 | 数据校验方法及装置、计算机存储介质、电子设备 |
Publications (1)
Publication Number | Publication Date |
---|---|
CN115016978A true CN115016978A (zh) | 2022-09-06 |
Family
ID=83067083
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
CN202210381797.9A Pending CN115016978A (zh) | 2022-04-12 | 2022-04-12 | 数据校验方法及装置、计算机存储介质、电子设备 |
Country Status (1)
Country | Link |
---|---|
CN (1) | CN115016978A (zh) |
Cited By (3)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN115544417A (zh) * | 2022-10-10 | 2022-12-30 | 中电金信软件有限公司 | 一种网页表单验证方法、装置、电子设备及存储介质 |
CN115620851A (zh) * | 2022-12-19 | 2023-01-17 | 一临云(深圳)科技有限公司 | 数据校验方法、装置、电子设备及可读存储介质 |
CN116401486A (zh) * | 2023-03-10 | 2023-07-07 | 优视科技有限公司 | 一种数据检测配置、数据检测方法、设备和介质 |
-
2022
- 2022-04-12 CN CN202210381797.9A patent/CN115016978A/zh active Pending
Cited By (4)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN115544417A (zh) * | 2022-10-10 | 2022-12-30 | 中电金信软件有限公司 | 一种网页表单验证方法、装置、电子设备及存储介质 |
CN115544417B (zh) * | 2022-10-10 | 2024-05-31 | 中电金信软件有限公司 | 一种网页表单验证方法、装置、电子设备及存储介质 |
CN115620851A (zh) * | 2022-12-19 | 2023-01-17 | 一临云(深圳)科技有限公司 | 数据校验方法、装置、电子设备及可读存储介质 |
CN116401486A (zh) * | 2023-03-10 | 2023-07-07 | 优视科技有限公司 | 一种数据检测配置、数据检测方法、设备和介质 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
US11257130B2 (en) | Method and system for review verification and trustworthiness scoring via blockchain | |
US10021193B2 (en) | Session table framework | |
CN115016978A (zh) | 数据校验方法及装置、计算机存储介质、电子设备 | |
JP2018533126A (ja) | データベースへの自然言語インタフェースのための方法、システム、およびコンピュータ・プログラム製品 | |
US11361008B2 (en) | Complex query handling | |
US20100121883A1 (en) | Reporting language filtering and mapping to dimensional concepts | |
AU2016302371A1 (en) | Building and managing data-processing attributes for modeled data sources | |
CN103150647B (zh) | 报表文件处理方法、服务器和系统 | |
US10958420B2 (en) | Method and system for blockchain-implemented project management | |
CN111242462B (zh) | 数据处理方法及装置、计算机存储介质、电子设备 | |
CN113076729B (zh) | 用于报表导入的方法及系统、可读存储介质及电子设备 | |
CN114328574A (zh) | 一种数据查询方法、装置、电子设备及计算机可读存储介质 | |
CN110869925A (zh) | 搜索中的多个实体感知的预输入 | |
CN112182037B (zh) | 数据校验方法、装置、设备以及存储介质 | |
CN111143383B (zh) | 一种数据更新方法、装置、电子设备及存储介质 | |
CN113094625A (zh) | 页面元素定位方法、装置、电子设备及存储介质 | |
US10838947B2 (en) | Consistency check for foreign key definition | |
CN115292313A (zh) | 一种伪列实现方法、装置、电子设备及存储介质 | |
US20220365921A1 (en) | Verifiable Cacheable Calclulations | |
CN115600038A (zh) | 页面渲染方法、装置、设备及介质 | |
US20230195792A1 (en) | Database management methods and associated apparatus | |
US11263533B2 (en) | Dynamic configurable rule representation | |
CN112559914A (zh) | 指标数据显示方法及装置 | |
CN107609871B (zh) | 支付轨迹重现方法、装置、系统、电子设备、存储介质 | |
US10698794B1 (en) | Application container and application service system |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
PB01 | Publication | ||
PB01 | Publication | ||
SE01 | Entry into force of request for substantive examination | ||
SE01 | Entry into force of request for substantive examination |