CN110309160B - 数据入链事务处理方法、装置、计算机设备及存储介质 - Google Patents
数据入链事务处理方法、装置、计算机设备及存储介质 Download PDFInfo
- Publication number
- CN110309160B CN110309160B CN201910429337.7A CN201910429337A CN110309160B CN 110309160 B CN110309160 B CN 110309160B CN 201910429337 A CN201910429337 A CN 201910429337A CN 110309160 B CN110309160 B CN 110309160B
- Authority
- CN
- China
- Prior art keywords
- data
- service data
- verification node
- block
- verification
- 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.)
- Active
Links
Images
Classifications
-
- 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/23—Updating
- G06F16/2365—Ensuring data consistency and integrity
-
- 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/27—Replication, distribution or synchronisation of data between databases or within a distributed database system; Distributed database system architectures therefor
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L63/00—Network architectures or network communication protocols for network security
- H04L63/12—Applying verification of the received information
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L63/00—Network architectures or network communication protocols for network security
- H04L63/12—Applying verification of the received information
- H04L63/123—Applying verification of the received information received data contents, e.g. message integrity
-
- Y—GENERAL TAGGING OF NEW TECHNOLOGICAL DEVELOPMENTS; GENERAL TAGGING OF CROSS-SECTIONAL TECHNOLOGIES SPANNING OVER SEVERAL SECTIONS OF THE IPC; TECHNICAL SUBJECTS COVERED BY FORMER USPC CROSS-REFERENCE ART COLLECTIONS [XRACs] AND DIGESTS
- Y02—TECHNOLOGIES OR APPLICATIONS FOR MITIGATION OR ADAPTATION AGAINST CLIMATE CHANGE
- Y02D—CLIMATE CHANGE MITIGATION TECHNOLOGIES IN INFORMATION AND COMMUNICATION TECHNOLOGIES [ICT], I.E. INFORMATION AND COMMUNICATION TECHNOLOGIES AIMING AT THE REDUCTION OF THEIR OWN ENERGY USE
- Y02D10/00—Energy efficient computing, e.g. low power processors, power management or thermal management
Landscapes
- Engineering & Computer Science (AREA)
- Computer Security & Cryptography (AREA)
- Theoretical Computer Science (AREA)
- General Engineering & Computer Science (AREA)
- Computing Systems (AREA)
- Databases & Information Systems (AREA)
- General Physics & Mathematics (AREA)
- Physics & Mathematics (AREA)
- Data Mining & Analysis (AREA)
- Computer Hardware Design (AREA)
- Computer Networks & Wireless Communication (AREA)
- Signal Processing (AREA)
- Information Retrieval, Db Structures And Fs Structures Therefor (AREA)
Abstract
本发明实施例公开了一种数据入链事务处理方法、装置、计算机设备及存储介质。本发明应用在研发管理中的事务处理过程优化领域。所述方法包括:若检测到用户新增业务数据,对业务数据进行校验;若所述业务数据校验通过,将所述业务数据写入到预设数据库;若将所述业务数据写入到预设数据库未发生异常,将所述业务数据发送至验证节点由所述验证节点对所述业务数据进行确认;若将所述业务数据发送至验证节点未发生异常,将所述验证节点所确认的区块写入到区块链;若上述操作发生异常,将所述业务数据回滚到新增业务数据之前的状态。通过实施本发明实施例的方法可减少区块链的脏数据,降低系统性能损耗。
Description
技术领域
本发明涉及区块链技术领域,尤其涉及一种数据入链事务处理方法、装置、计算机设备及存储介质。
背景技术
随着科技与经济的发展,区块链的技术已逐渐成熟,应用于各个行业当中。尤其是在贸易行业中,基于区块链技术可以有效地解决交易信任的问题,极大地促进了贸易行业的发展。然而,在基于区块链的贸易平台中,交易订单数量巨大,交易频繁,交易币种多样,由此产生的业务数据时常会出现异常。而在处理新增业务数据时,通常是首先执行区块链写链操作,然后再执行数据库写库操作,最后再执行通讯操作,但是当数据库写库或者通讯操作发生异常时,需要通知区块链进行数据回滚,此时由于区块链未能增加事务处理,会存在脏数据的问题。
发明内容
本发明实施例提供了一种数据入链事务处理方法、装置、计算机设备及存储介质,旨在解决数据入链异常时,由于区块链未能增加事务处理导致存在脏数据的问题。
第一方面,本发明实施例提供了一种数据入链事务处理方法,其包括:若检测到用户新增业务数据,对所述业务数据进行校验;若所述业务数据校验通过,将所述业务数据写入到预设数据库;若将所述业务数据写入到预设数据库未发生异常,将所述业务数据发送至验证节点由所述验证节点对所述业务数据进行确认;若将所述业务数据发送至验证节点未发生异常,将所述验证节点所确认的区块写入到区块链;若将所述业务数据写入到预设数据库发生异常或将所述业务数据发送至验证节点发生异常或将所述验证节点所确认的区块写入到区块链发生异常,将所述业务数据回滚到新增业务数据之前的状态。
第二方面,本发明实施例还提供了一种数据入链事务处理装置,其包括:校验单元,用于若检测到用户新增业务数据,对所述业务数据进行校验;写库单元,用于若所述业务数据校验通过,将所述业务数据写入到预设数据库;发送单元,用于若将所述业务数据写入到预设数据库未发生异常,将所述业务数据发送至验证节点由所述验证节点对所述业务数据进行确认;写链单元,用于若将所述业务数据发送至验证节点未发生异常,将所述验证节点所确认的区块写入到区块链;回滚单元,用于若将所述业务数据写入到预设数据库发生异常或将所述业务数据发送至验证节点发生异常或将所述验证节点所确认的区块写入到区块链发生异常,将所述业务数据回滚到新增业务数据之前的状态。
第三方面,本发明实施例还提供了一种计算机设备,其包括存储器及处理器,所述存储器上存储有计算机程序,所述处理器执行所述计算机程序时实现上述方法。
第四方面,本发明实施例还提供了一种计算机可读存储介质,所述存储介质存储有计算机程序,所述计算机程序当被处理器执行时可实现上述方法。
本发明实施例提供了一种数据入链事务处理方法、装置、计算机设备及存储介质。其中,所述方法包括:若检测到用户新增业务数据,对所述业务数据进行校验;若所述业务数据校验通过,将所述业务数据写入到预设数据库;若将所述业务数据写入到预设数据库未发生异常,将所述业务数据发送至验证节点由所述验证节点对所述业务数据进行确认;若将所述业务数据发送至验证节点未发生异常,将所述验证节点所确认的区块写入到区块链;若将所述业务数据写入到预设数据库发生异常或将所述业务数据发送至验证节点发生异常或将所述验证节点所确认的区块写入到区块链发生异常,将所述业务数据回滚到新增业务数据之前的状态。本发明实施例由于对数据入链事务处理调整了执行顺序,可实现减少区块链脏数据,降低系统性能损耗的效果。
附图说明
为了更清楚地说明本发明实施例技术方案,下面将对实施例描述中所需要使用的附图作简单地介绍,显而易见地,下面描述中的附图是本发明的一些实施例,对于本领域普通技术人员来讲,在不付出创造性劳动的前提下,还可以根据这些附图获得其他的附图。
图1为本发明实施例提供的数据入链事务方法的应用场景示意图;
图2为本发明实施例提供的数据入链事务处理方法的流程示意图;
图3为本发明实施例提供的数据入链事务处理方法的子流程示意图;
图4为本发明实施例提供的数据入链事务处理方法的子流程示意图;
图5为本发明实施例提供的数据入链事务处理方法的子流程示意图;
图6为本发明实施例提供的数据入链事务处理方法的子流程示意图
图7为本发明实施例提供的数据入链事务处理装置的示意性框图;
图8为本发明实施例提供的数据入链事务处理装置的具体单元的示意性框图;以及
图9为本发明实施例提供的计算机设备的示意性框图。
具体实施方式
下面将结合本发明实施例中的附图,对本发明实施例中的技术方案进行清楚、完整地描述,显然,所描述的实施例是本发明一部分实施例,而不是全部的实施例。基于本发明中的实施例,本领域普通技术人员在没有做出创造性劳动前提下所获得的所有其他实施例,都属于本发明保护的范围。
应当理解,当在本说明书和所附权利要求书中使用时,术语“包括”和“包含”指示所描述特征、整体、步骤、操作、元素和/或组件的存在,但并不排除一个或多个其它特征、整体、步骤、操作、元素、组件和/或其集合的存在或添加。
还应当理解,在此本发明说明书中所使用的术语仅仅是出于描述特定实施例的目的而并不意在限制本发明。如在本发明说明书和所附权利要求书中所使用的那样,除非上下文清楚地指明其它情况,否则单数形式的“一”、“一个”及“该”意在包括复数形式。
还应当进一步理解,在本发明说明书和所附权利要求书中使用的术语“和/或”是指相关联列出的项中的一个或多个的任何组合以及所有可能组合,并且包括这些组合。
请参阅图1和图2,图1为本发明实施例提供的数据入链事务处理方法的应用场景示意图。图2为本发明实施例提供的数据入链事务处理方法的示意性流程图。该数据入链事务处理方法应用于终端10中,通过终端10与服务器20之间交互实现。本发明提出的一种区块链数据入链事务处理方法,应用于基于区块链的贸易平台中。在基于区块链的贸易平台中处理区块链数据入链事务时,由于数据库写库操作或通讯操作异常时会导致区块链存在脏数据。因此,通过本发明提出的区块链数据入链事务处理方法,充分考虑异常发生的可能性、事务回滚的难易以及业务是否可处理,对区块链写链操作、数据库写库操作以及通讯操作进行重新排序,将异常发生率高的数据库写库操作放在首位执行,将事务处理容易的通讯操作放在次位执行,将增加事务管理难的区块链写链操作放在最后执行。通过上述设计,当数据库写库操作或者通讯操作又或者区块链写链操作发生异常时,可将整个事务回滚,减少了区块链的脏数据,且事务回滚提前,能够减少系统性能损耗。
图2是本发明实施例提供的数据入链事务处理方法的流程示意图。如图所示,该方法包括以下步骤S110-S150。
S110、若检测到用户新增业务数据,对所述业务数据进行校验。
在一实施例中,业务数据指的是用户在贸易平台中对订单进行一系列操作所产生的数据,如新增订单、删除订单以及修改订单等。校验指的是对用户新增的业务数据的合法性和完整性进行验证。通常在贸易平台中用户新增一个订单,首先需要登录账号,在账户中录入订单相关信息并确认订单,当系统检测到用户提交的业务数据,随即执行对业务数据的合法性和完整性进行校验。业务数据的校验在数据入链事务处理前执行,若业务数据校验通过则可执行数据入链事务,若业务数据校验不通过,则返回,用户重新操作。
在一实施例中,如图3所示,所述步骤S110可包括步骤:S111-S113。
S111、根据用户标签对所述业务数据的合法性进行校验。
在一实施例中,用户标签指的是用于标识用户身份的信息,即cookie,其包括用户账号以及密码,例如,DJ001,password:123456,用户标识符可区分每一个用户的身份。用户在提交业务数据时用户标签跟随业务数据一并提交,当检测到用户新增业务数据后,根据接收到的用户标签与数据库中存储的对应该用户的账号以及密码进行对比,判断新增业务数据的用户其用户标签是否与数据库中存储的用户账号以及密码相一致,若一致说明业务数据是由该用户新增的,判定业务数据合法;若不一致说明业务数据不是由该用户新增的,判定业务数据不合法。
S112、根据预设规则对所述业务数据的完整性进行校验。
在一实施例中,预设规则指的是业务数据完整性的校验规则。由于数据在传输的过程中会受到各种干扰的影响,如脉冲干扰,随机噪声干扰和人为干扰等,这会使数据产生差错,因此为了能够控制传输过程的差错,需要对数据的完整性进行校验。校验的主要方法是通过一种指定的算法对所提交的业务数据计算出的一个校验值,当接收到业务数据后通过同样的算法计算一次校验值,如果两次计算得到的检验值相同,则说明数据是完整的判定业务数据完整,其中,校验的算法可以是奇偶校验、CRC循环冗余校验或者MD5校验中的任意一种。
S113、若所述业务数据合法且完整,判定所述业务数据校验通过。
在一实施例中,只有当业务数据的合法性和完整性均校验通过后,才可判定业务数据校验通过。
S120、若所述业务数据校验通过,将所述业务数据写入到预设数据库。
在一实施例中,预设数据库指的是贸易平台的数据库,用于存储该贸易平台中产生的业务数据。在业务数据校验通过后,即可执行业务数据入链事务,首先第一步操作是写库操作,将新增的业务数据写入到数据库中进行存储,且在写库的过程中检测是否发生异常。例如,修改订单金额,将订单金额从50万增加到100万,那么则将修改的订单金额100万替换掉预设数据库中的订单金额50万并进行存储。
在一实施例中,如图4所示,所述步骤S120可包括步骤:S121-S122。
S121、判断将所述业务数据写入到预设数据库是否违反唯一约束。
S122、若将所述业务数据写入到预设数据库违反唯一约束,判定将所述业务数据写入到预设数据库发生异常。
在一实施例中,唯一约束指的是保证在一个字段或者一组字段里的数据与表中其它行的数据相比是唯一的。业务数据以表的形式存储在预设数据库中,若新增的业务数据写入到预设数据库中出现违反唯一约束异常,说明新增的业务数据在预设数据库的表中不是唯一的,写入了重复的值。例如,预设数据库中已存在了X订单,而用户又新增了一个X订单,当新增的X订单写入到预设数据库时则违反唯一约束异常,写入失败判定发生异常。
S130、若将所述业务数据写入到预设数据库未发生异常,将所述业务数据发送至验证节点由所述验证节点对所述业务数据进行确认。
在一实施例中,验证节点指的是区块链网络中用于确认业务数据有效的节点。在执行完第一步的写库操作后,执行第二步通讯操作,即将业务数据发送到服务器中,其他验证节点接收到业务数据后对业务数据的有效性进行确认。由于业务数据在发送的过程中可能会出现发送不成功的情况,因此在执行通讯操作的过程中需要判断业务数据是否成功发送至验证节点。在业务数据发送至验证节点前,需要对业务数据进行加密,具体地,根据用户预配置的私钥对业务数据进行加密,验证节点接收到业务数据后通过与私钥对应的公钥解密后再对业务数据进行确认。其中,私钥指的是通过非对称加密算法分配的密钥,非对称加密算法在加密和解密时使用的是两个不相同的密钥,分别称为公钥和私钥,通过公钥加密的数据只有私钥才能解密,通过私钥加密的数据只有公钥才能解密。私钥通过随机数算法生成,公钥根据私钥生成,公钥和私钥成对分配,其中,公钥匙公开的,私钥是私人持有且严密保护的,每个用户预配置一对公钥和私钥。
在一实施例中,如图5所示,所述步骤S130可包括步骤:S131-S133。
S131、判断所述业务数据是否成功发送至验证节点;
S132、若所述业务数据未成功发送至验证节点,判断所述业务数据发送至所述验证节点失败的次数是否达到预设阈值;
S133、若所述业务发送至所述验证节点的失败次数达到预设阈值,判定将所述业务数据发送至验证节点发生异常。
在一实施例中,在执行通讯操作的过程中,业务数据的数据量过大导致发送超时,或者通讯节点瘫痪导致通讯连接断开无法传输数据,这些原因均会导致业务数据发送失败。业务数据成功发送后服务器会返回发送成功的消息,因此若在一定时间能没有响应未接收到服务器返回的发送成功的消息,说明业务数据发送失败,此时则生成提示消息提示用户重新连接网络再次发送业务数据。统计用户重新发送业务数据失败的次数,当重新发送业务数据失败的次数达到预设阈值后,则判定发生异常,其中预设阈值为3次,当然可以理解的是,还可以是其他任意设定的次数。
S140、若将所述业务数据发送至验证节点未发生异常,将所述验证节点所确认的区块写入到区块链。
在一实施例中,所述验证节点接收到业务数据后,根据用户公开的公钥对业务数据进行解密验证用户的身份和业务数据的完整性,验证通过后则通过共识机制对业务数据进行确认。共识机制指的是区块链网络中的各验证节点怎么达成共识一致确认区块有效的手段,验证节点通过将接收的业务数据打包到区块中进行哈希计算完成工作量证明并由其他验证节点共同确认从而得到确认有效的区块。在验证节点确认区块有效后,接收验证节点所确认的区块,执行第三步写链操作,将该区块写入到本地维护的区块链中。
在一实施例中,如图6所示,所述步骤S140可包括步骤:S141-S142。
S141、判断所述验证节点所确认的区块中是否存在所述业务数据。
S142、若所述验证节点所确认的区块中不存在所述业务数据,判定将所述验证节点所确认的区块写入到区块链发生异常。
在一实施例中,接收验证节点广播到区块链网络中的确认区块,执行第三步写链操作,根据哈希算法对验证节点所确认的区块进行哈希运算得到该区块中存储的数据,将预设数据库中的业务数据与该区块中存储的数据进行对比,判断该区块中存储的数据中是否存在有与业务数据相同的数据,若存在,说明业务数据被验证节点确认有效可以写入到本地维护的区块链中;若不存在,说明业务数据未被验证节点确认有效,产生了区块链的脏数据,不可以写入到本地维护的区块链中,判定发生异常。
S150、若将所述业务数据写入到预设数据库发生异常或将所述业务数据发送至验证节点发生异常或将所述验证节点所确认的区块写入到区块链发生异常,将所述业务数据回滚到新增业务数据之前的状态。
在一实施例中,回滚指的是数据处理错误将数据恢复到上一次正确状态的行为,上述在数据库写库、业务数据发送即通讯操作以及区块写链的过程中发生异常,则执行数据回滚将业务数据恢复到用户新增业务数据之前的状态。例如,在数据库写库过程中发生异常,则在预设数据库中将业务数据进行回滚恢复到未新增业务数据的状态,减少系统性能损耗,减少了区块链的脏数据。
本发明实施例提供的一种数据入链事务处理方法,通过若检测到用户新增业务数据,对所述业务数据进行校验;若所述业务数据校验通过,将所述业务数据写入到预设数据库;若将所述业务数据写入到预设数据库未发生异常,将所述业务数据发送至验证节点由所述验证节点对所述业务数据进行确认;若将所述业务数据发送至验证节点未发生异常,将所述验证节点所确认的区块写入到区块链;若将所述业务数据写入到预设数据库发生异常或将所述业务数据发送至验证节点发生异常或将所述验证节点所确认的区块写入到区块链发生异常,将所述业务数据回滚到新增业务数据之前的状态,可以在数据入链事务处理过程中,减少了区块链的脏数据,降低系统性能损耗。
图7是本发明实施例提供的一种数据入链事务处理装置200的示意性框图。如图7所示,对应于以上数据入链事务处理方法,本发明还提供一种数据入链事务处理装置200。该数据入链事务处理装置200包括用于执行上述数据入链事务处理方法的单元,该装置可以被配置于台式电脑、平板电脑、手提电脑、等终端中。具体地,请参阅图7,该数据入链事务处理装置200包括:校验单元210、写库单元220、发送单元230、写链单元240以及回滚单元250。
校验单元210,用于若检测到用户新增业务数据,对所述业务数据进行校验。
在一实施例中中,如图8所示,所述校验单元210包括:第一校验子单元211、第二校验子单元212以及判定子单元213。
第一校验子单元211,用于根据用户标签对所述业务数据的合法性进行校验。
第二校验子单元212,用于根据预设规则对所述业务数据的完整性进行校验。
判定子单元213,用于若所述业务数据合法且完整,判定所述业务数据校验通过。
写库单元220,用于若所述业务数据校验通过,将所述业务数据写入到预设数据库。
在一实施例中中,如图8所示,所述写库单元220包括:第一判断子单元221以及第一判定子单元222。
第一判断子单元221,用于判断将所述业务数据写入到预设数据库是否违反唯一约束。
第一判定子单元222,用于若将所述业务数据写入到预设数据库违反唯一约束,判定将所述业务数据写入到预设数据库发生异常。
发送单元230,用于若将所述业务数据写入到预设数据库未发生异常,将所述业务数据发送至验证节点由所述验证节点对所述业务数据进行确认。
在一实施例中中,如图8所示,所述发送单元230包括:发送判断单元231、第二判断子单元232以及第二判定子单元233。
发送判断单元231,用于判断所述业务数据是否成功发送至验证节点。
第二判断子单元232,用于若所述业务数据未成功发送至验证节点,判断所述业务数据发送至所述验证节点失败的次数是否达到预设阈值。
第二判定子单元233,用于若所述业务发送至所述验证节点的失败次数达到预设阈值,判定将所述业务数据发送至验证节点发生异常。
写链单元240,用于若将所述业务数据发送至验证节点未发生异常,将所述验证节点所确认的区块写入到区块链。
在一实施例中中,如图8所示,所述写链单元240包括:第三判断子单元241以及第三判定子单元242。
第三判断子单元241,用于判断所述验证节点所确认的区块中是否存在所述业务数据;
第三判定子单元242,用于若所述验证节点所确认的区块中不存在所述业务数据,判定将所述验证节点所确认的区块写入到区块链发生异常。
回滚单元250,用于若将所述业务数据写入到预设数据库发生异常或将所述业务数据发送至验证节点发生异常或将所述验证节点所确认的区块写入到区块链发生异常,将所述业务数据回滚到新增业务数据之前的状态。
需要说明的是,所属领域的技术人员可以清楚地了解到,上述数据入链事务处理装置200和各单元的具体实现过程,可以参考前述方法实施例中的相应描述,为了描述的方便和简洁,在此不再赘述。
上述数据入链事务处理装置可以实现为一种计算机程序的形式,该计算机程序可以在如图9所示的计算机设备上运行。
请参阅图9,图9是本申请实施例提供的一种计算机设备的示意性框图。该计算机设备500可以是终端,其中,终端可以是智能手机、平板电脑、笔记本电脑、台式电脑、个人数字助理和穿戴式设备等具有通信功能的电子设备。
参阅图9,该计算机设备500包括通过系统总线501连接的处理器502、存储器和网络接口505,其中,存储器可以包括非易失性存储介质503和内存储器504。
该非易失性存储介质503可存储操作系统5031和计算机程序5032。该计算机程序5032包括程序指令,该程序指令被执行时,可使得处理器502执行一种第三判定子单元232方法。
该处理器502用于提供计算和控制能力,以支撑整个计算机设备500的运行。
该内存储器504为非易失性存储介质503中的计算机程序5032的运行提供环境,该计算机程序5032被处理器502执行时,可使得处理器502执行一种第三判定子单元232方法。
该网络接口505用于与其它设备进行网络通信。本领域技术人员可以理解,图9中示出的结构,仅仅是与本申请方案相关的部分结构的框图,并不构成对本申请方案所应用于其上的计算机设备500的限定,具体的计算机设备500可以包括比图中所示更多或更少的部件,或者组合某些部件,或者具有不同的部件布置。
其中,所述处理器502用于运行存储在存储器中的计算机程序5032,以实现如下步骤:若检测到用户新增业务数据,对所述业务数据进行校验;若所述业务数据校验通过,将所述业务数据写入到预设数据库;若将所述业务数据写入到预设数据库未发生异常,将所述业务数据发送至验证节点由所述验证节点对所述业务数据进行确认;若将所述业务数据发送至验证节点未发生异常,将所述验证节点所确认的区块写入到区块链;若将所述业务数据写入到预设数据库发生异常或将所述业务数据发送至验证节点发生异常或将所述验证节点所确认的区块写入到区块链发生异常,将所述业务数据回滚到新增业务数据之前的状态。
在一实施例中,处理器502在实现所述对所述业务数据进行校验步骤时,具体实现如下步骤:根据用户标签对所述业务数据的合法性进行校验;根据预设规则对所述业务数据的完整性进行校验;若所述业务数据合法且完整,判定所述业务数据校验通过。
在一实施例中,处理器502在实现所述将所述业务数据写入到预设数据库步骤时,具体实现如下步骤:判断将所述业务数据写入到预设数据库是否违反唯一约束;若将所述业务数据写入到预设数据库违反唯一约束,判定将所述业务数据写入到预设数据库发生异常。
在一实施例中,处理器502在实现所述将所述业务数据发送至验证节点由所述验证节点对所述业务数据进行确认步骤时,具体实现如下步骤:判断所述业务数据是否成功发送至验证节点;若所述业务数据未成功发送至验证节点,判断所述业务数据发送至所述验证节点失败的次数是否达到预设阈值;若所述业务发送至所述验证节点的失败次数达到预设阈值,判定将所述业务数据发送至验证节点发生异常。
在一实施例中,处理器502在实现所述将所述验证节点所确认的区块写入到区块链步骤时,具体实现如下步骤:判断所述验证节点所确认的区块中是否存在所述业务数据;若所述验证节点所确认的区块中不存在所述业务数据,判定将所述验证节点所确认的区块写入到区块链发生异常。
应当理解,在本申请实施例中,处理器502可以是中央处理单元(CentralProcessing Unit,CPU),该处理器502还可以是其他通用处理器、数字信号处理器(DigitalSignal Processor,DSP)、专用集成电路(Application Specific Integrated Circuit,ASIC)、现成可编程门阵列(Field-Programmable Gate Array,FPGA)或者其他可编程逻辑器件、分立门或者晶体管逻辑器件、分立硬件组件等。其中,通用处理器可以是微处理器或者该处理器也可以是任何常规的处理器等。
本领域普通技术人员可以理解的是实现上述实施例的方法中的全部或部分流程,是可以通过计算机程序来指令相关的硬件来完成。该计算机程序包括程序指令,计算机程序可存储于一存储介质中,该存储介质为计算机可读存储介质。该程序指令被该计算机系统中的至少一个处理器执行,以实现上述方法的实施例的流程步骤。
因此,本发明还提供一种存储介质。该存储介质可以为计算机可读存储介质。该存储介质存储有计算机程序,其中计算机程序包括程序指令。该程序指令被处理器执行时使处理器执行如下步骤:若检测到用户新增业务数据,对所述业务数据进行校验;若所述业务数据校验通过,将所述业务数据写入到预设数据库;若将所述业务数据写入到预设数据库未发生异常,将所述业务数据发送至验证节点由所述验证节点对所述业务数据进行确认;若将所述业务数据发送至验证节点未发生异常,将所述验证节点所确认的区块写入到区块链;若将所述业务数据写入到预设数据库发生异常或将所述业务数据发送至验证节点发生异常或将所述验证节点所确认的区块写入到区块链发生异常,将所述业务数据回滚到新增业务数据之前的状态。
在一实施例中,所述处理器在执行所述程序指令而实现所述对所述业务数据进行校验步骤时,具体实现如下步骤:根据用户标签对所述业务数据的合法性进行校验;根据预设规则对所述业务数据的完整性进行校验;若所述业务数据合法且完整,判定所述业务数据校验通过。
在一实施例中,所述处理器在执行所述程序指令而实现所述将所述业务数据写入到预设数据库步骤时,具体实现如下步骤:判断将所述业务数据写入到预设数据库是否违反唯一约束;若将所述业务数据写入到预设数据库违反唯一约束,判定将所述业务数据写入到预设数据库发生异常。
在一实施例中,所述处理器在执行所述程序指令而实现所述将所述业务数据发送至验证节点由所述验证节点对所述业务数据进行确认步骤时,具体实现如下步骤:判断所述业务数据是否成功发送至验证节点;若所述业务数据未成功发送至验证节点,判断所述业务数据发送至所述验证节点失败的次数是否达到预设阈值;若所述业务发送至所述验证节点的失败次数达到预设阈值,判定将所述业务数据发送至验证节点发生异常。
在一实施例中,所述处理器在执行所述程序指令而实现所述将所述验证节点所确认的区块写入到区块链步骤时,具体实现如下步骤:判断所述验证节点所确认的区块中是否存在所述业务数据;若所述验证节点所确认的区块中不存在所述业务数据,判定将所述验证节点所确认的区块写入到区块链发生异常。
所述存储介质可以是U盘、移动硬盘、只读存储器(Read-Only Memory,ROM)、磁碟或者光盘等各种可以存储程序代码的计算机可读存储介质。
本领域普通技术人员可以意识到,结合本文中所公开的实施例描述的各示例的单元及算法步骤,能够以电子硬件、计算机软件或者二者的结合来实现,为了清楚地说明硬件和软件的可互换性,在上述说明中已经按照功能一般性地描述了各示例的组成及步骤。这些功能究竟以硬件还是软件方式来执行,取决于技术方案的特定应用和设计约束条件。专业技术人员可以对每个特定的应用来使用不同方法来实现所描述的功能,但是这种实现不应认为超出本发明的范围。
在本发明所提供的几个实施例中,应该理解到,所揭露的装置和方法,可以通过其它的方式实现。例如,以上所描述的装置实施例仅仅是示意性的。例如,各个单元的划分,仅仅为一种逻辑功能划分,实际实现时可以有另外的划分方式。例如多个单元或组件可以结合或者可以集成到另一个系统,或一些特征可以忽略,或不执行。
本发明实施例方法中的步骤可以根据实际需要进行顺序调整、合并和删减。本发明实施例装置中的单元可以根据实际需要进行合并、划分和删减。另外,在本发明各个实施例中的各功能单元可以集成在一个处理单元中,也可以是各个单元单独物理存在,也可以是两个或两个以上单元集成在一个单元中。
该集成的单元如果以软件功能单元的形式实现并作为独立的产品销售或使用时,可以存储在一个存储介质中。基于这样的理解,本发明的技术方案本质上或者说对现有技术做出贡献的部分,或者该技术方案的全部或部分可以以软件产品的形式体现出来,该计算机软件产品存储在一个存储介质中,包括若干指令用以使得一台计算机设备(可以是个人计算机,终端,或者网络设备等)执行本发明各个实施例所述方法的全部或部分步骤。
以上所述,仅为本发明的具体实施方式,但本发明的保护范围并不局限于此,任何熟悉本技术领域的技术人员在本发明揭露的技术范围内,可轻易想到各种等效的修改或替换,这些修改或替换都应涵盖在本发明的保护范围之内。因此,本发明的保护范围应以权利要求的保护范围为准。
Claims (8)
1.一种数据入链事务处理方法,其特征在于,包括:
若检测到用户新增业务数据,对所述业务数据进行校验;
若所述业务数据校验通过,将所述业务数据写入到预设数据库;
若将所述业务数据写入到预设数据库未发生异常,将所述业务数据发送至验证节点由所述验证节点对所述业务数据进行确认;
若将所述业务数据发送至验证节点未发生异常,将所述验证节点所确认的区块写入到区块链;
若将所述业务数据写入到预设数据库发生异常或将所述业务数据发送至验证节点发生异常或将所述验证节点所确认的区块写入到区块链发生异常,将所述业务数据回滚到新增业务数据之前的状态;
所述将所述验证节点所确认的区块写入到区块链,包括:
接收所述验证节点广播到区块链网络中的确认区块,根据哈希算法对验证节点所确认的区块进行哈希运算得到该区块中存储的数据;
将预设数据库中的业务数据与该区块中存储的数据进行对比,判断该区块中存储的数据中是否存在有与业务数据相同的数据;
若不存在,判定将所述验证节点所确认的区块写入到区块链发生异常。
2.根据权利要求1所述的数据入链事务处理方法,其特征在于,所述对所述业务数据进行校验,包括:
根据用户标签对所述业务数据的合法性进行校验;
根据预设规则对所述业务数据的完整性进行校验;
若所述业务数据合法且完整,判定所述业务数据校验通过。
3.根据权利要求1所述的数据入链事务处理方法,其特征在于,所述将所述业务数据写入到预设数据库,包括:
判断将所述业务数据写入到预设数据库是否违反唯一约束;
若将所述业务数据写入到预设数据库违反唯一约束,判定将所述业务数据写入到预设数据库发生异常。
4.根据权利要求1所述的数据入链事务处理方法,其特征在于,所述将所述业务数据发送至验证节点由所述验证节点对所述业务数据进行确认,包括:
判断所述业务数据是否成功发送至验证节点;
若所述业务数据未成功发送至验证节点,判断所述业务数据发送至所述验证节点失败的次数是否达到预设阈值;
若所述业务发送至所述验证节点的失败次数达到预设阈值,判定将所述业务数据发送至验证节点发生异常。
5.一种数据入链事务处理装置,其特征在于,包括:
校验单元,用于若检测到用户新增业务数据,对所述业务数据进行校验;
写库单元,用于若所述业务数据校验通过,将所述业务数据写入到预设数据库;
发送单元,用于若将所述业务数据写入到预设数据库未发生异常,将所述业务数据发送至验证节点由所述验证节点对所述业务数据进行确认;
写链单元,用于若将所述业务数据发送至验证节点未发生异常,将所述验证节点所确认的区块写入到区块链,所述将所述验证节点所确认的区块写入到区块链,包括:接收所述验证节点广播到区块链网络中的确认区块,根据哈希算法对验证节点所确认的区块进行哈希运算得到该区块中存储的数据;将预设数据库中的业务数据与该区块中存储的数据进行对比,判断该区块中存储的数据中是否存在有与业务数据相同的数据;若不存在,判定将所述验证节点所确认的区块写入到区块链发生异常;
回滚单元,用于若将所述业务数据写入到预设数据库发生异常或将所述业务数据发送至验证节点发生异常或将所述验证节点所确认的区块写入到区块链发生异常,将所述业务数据回滚到新增业务数据之前的状态。
6.根据权利要求5所述的数据入链事务处理装置,其特征在于,所述写库单元包括:
第一判断子单元,用于判断将所述业务数据写入到预设数据库是否违反唯一约束;
第一判定子单元,用若将所述业务数据写入到预设数据库违反唯一约束,判定将所述业务数据写入到预设数据库发生异常。
7.一种计算机设备,其特征在于,所述计算机设备包括存储器及处理器,所述存储器上存储有计算机程序,所述处理器执行所述计算机程序时实现如权利要求1-4中任一项所述的方法。
8.一种计算机可读存储介质,其特征在于,所述存储介质存储有计算机程序,所述计算机程序当被处理器执行时可实现如权利要求1-4中任一项所述的方法。
Priority Applications (2)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN201910429337.7A CN110309160B (zh) | 2019-05-22 | 2019-05-22 | 数据入链事务处理方法、装置、计算机设备及存储介质 |
PCT/CN2019/103172 WO2020232885A1 (zh) | 2019-05-22 | 2019-08-29 | 数据入链事务处理方法、装置、计算机设备及存储介质 |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN201910429337.7A CN110309160B (zh) | 2019-05-22 | 2019-05-22 | 数据入链事务处理方法、装置、计算机设备及存储介质 |
Publications (2)
Publication Number | Publication Date |
---|---|
CN110309160A CN110309160A (zh) | 2019-10-08 |
CN110309160B true CN110309160B (zh) | 2023-07-04 |
Family
ID=68074717
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
CN201910429337.7A Active CN110309160B (zh) | 2019-05-22 | 2019-05-22 | 数据入链事务处理方法、装置、计算机设备及存储介质 |
Country Status (2)
Country | Link |
---|---|
CN (1) | CN110309160B (zh) |
WO (1) | WO2020232885A1 (zh) |
Families Citing this family (5)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN112800040B (zh) * | 2021-01-22 | 2024-02-06 | 平安养老保险股份有限公司 | 业务数据校验方法、装置、计算机设备及存储介质 |
CN113704254B (zh) * | 2021-07-30 | 2023-06-16 | 北京奇艺世纪科技有限公司 | 一种数据库的业务处理方法、装置、电子设备和存储介质 |
CN115018622B (zh) * | 2022-05-25 | 2024-03-26 | 平安银行股份有限公司 | 业务重构系统的验证方法、装置、设备及可读存储介质 |
CN115242349B (zh) * | 2022-06-21 | 2023-11-14 | 苏州盈数智能科技有限公司 | 企业级数据校验方法、装置、计算机设备及存储介质 |
CN116560896B (zh) * | 2023-07-11 | 2023-10-10 | 智慧眼科技股份有限公司 | 一种异常补偿方法、装置、设备及存储介质 |
Family Cites Families (10)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN111741494B (zh) * | 2015-07-14 | 2023-01-10 | Oppo广东移动通信有限公司 | 数据传输的方法、发送设备及接收设备 |
US10713654B2 (en) * | 2016-01-21 | 2020-07-14 | International Business Machines Corporation | Enterprise blockchains and transactional systems |
CN106611061B (zh) * | 2016-12-29 | 2018-02-23 | 北京众享比特科技有限公司 | 基于区块链网络的数据库写入方法及系统 |
CN108427601A (zh) * | 2017-02-13 | 2018-08-21 | 北京航空航天大学 | 一种私有链节点的集群交易处理方法 |
CN108573741A (zh) * | 2017-12-25 | 2018-09-25 | 北京金山云网络技术有限公司 | 业务数据记录方法、装置、设备和存储介质 |
CN108712431B (zh) * | 2018-05-24 | 2021-09-21 | 广东工业大学 | 一种基于联盟链的交通信息存放方法及装置 |
CN109033143B (zh) * | 2018-06-11 | 2021-06-29 | 中国科学院广州能源研究所 | 基于区块链的分布式、分域电网数据处理系统及其方法 |
CN109191355B (zh) * | 2018-08-21 | 2022-02-25 | 严治 | 一种基于区块链的创伤数据共享系统 |
CN109446208A (zh) * | 2018-09-03 | 2019-03-08 | 深圳壹账通智能科技有限公司 | 一种数据存储方法、计算机可读存储介质及服务器 |
CN109446273B (zh) * | 2018-12-04 | 2022-07-22 | 深圳前海环融联易信息科技服务有限公司 | 区块链的数据同步方法、装置、计算机设备及存储介质 |
-
2019
- 2019-05-22 CN CN201910429337.7A patent/CN110309160B/zh active Active
- 2019-08-29 WO PCT/CN2019/103172 patent/WO2020232885A1/zh active Application Filing
Also Published As
Publication number | Publication date |
---|---|
WO2020232885A1 (zh) | 2020-11-26 |
CN110309160A (zh) | 2019-10-08 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
CN110309160B (zh) | 数据入链事务处理方法、装置、计算机设备及存储介质 | |
CN110708171B (zh) | 区块链共识投票方法、装置、设备以及存储介质 | |
WO2021012552A1 (zh) | 一种登录处理方法及相关设备 | |
US9292665B2 (en) | Secure serial number | |
US7996713B2 (en) | Server-to-server integrity checking | |
US9342683B2 (en) | Stateless attestation system | |
JP5510590B2 (ja) | 伝送システムと方法ならびにプログラム | |
CN109905360B (zh) | 数据验证方法及终端设备 | |
CN100383694C (zh) | 为可被具有安全模块的用户设备执行的事务维护私密 | |
CN111200589A (zh) | 一种联盟链的数据保护方法及系统 | |
CN109586949B (zh) | 区块生成方法及计算机存储介质 | |
KR20230147761A (ko) | 블록체인 기반 데이터의 인증된 수정 | |
US20160080376A1 (en) | Method and device for checking an identifier | |
CN115589298B (zh) | 区块链的信息验证方法、装置和系统、设备、介质 | |
CN111291415A (zh) | 数据存储方法、装置及业务系统服务器 | |
CN111131218A (zh) | 一种黑名单管理方法、装置、计算机系统及可读存储介质 | |
WO2023019841A1 (zh) | 数据审计方法及装置 | |
CN109800579A (zh) | 一种软件的完整性校验方法、装置及电子设备 | |
CN112948847B (zh) | 基于区块链的数据共享系统及数据正确性验证方法 | |
CN110766407A (zh) | 基于区块链的交易验证方法、记账节点及介质 | |
CN101656719B (zh) | 一种可实现平台配置保护的双向平台鉴别方法 | |
US20220109577A1 (en) | Method for verifying the state of a distributed ledger and distributed ledger | |
CN116881939A (zh) | 基于数字签名算法选择的加密校验方法、装置及设备 | |
CN111526122A (zh) | 数据监控的方法、装置、设备及介质 | |
CN115587391A (zh) | 双向认证管理方法、系统、终端及计算机存储介质 |
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 | ||
GR01 | Patent grant | ||
GR01 | Patent grant |