CN111342972B - 一种区块链的事务实现方法、装置、设备和介质 - Google Patents
一种区块链的事务实现方法、装置、设备和介质 Download PDFInfo
- Publication number
- CN111342972B CN111342972B CN202010113572.6A CN202010113572A CN111342972B CN 111342972 B CN111342972 B CN 111342972B CN 202010113572 A CN202010113572 A CN 202010113572A CN 111342972 B CN111342972 B CN 111342972B
- Authority
- CN
- China
- Prior art keywords
- transaction
- chain
- verification
- execution
- information
- 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
- 238000000034 method Methods 0.000 title claims abstract description 73
- 238000012795 verification Methods 0.000 claims abstract description 219
- 238000010200 validation analysis Methods 0.000 claims description 24
- 230000008569 process Effects 0.000 claims description 21
- 230000015654 memory Effects 0.000 claims description 19
- 238000007599 discharging Methods 0.000 claims 4
- 230000008901 benefit Effects 0.000 description 9
- 230000006870 function Effects 0.000 description 6
- 230000009286 beneficial effect Effects 0.000 description 5
- 238000010586 diagram Methods 0.000 description 5
- 238000012545 processing Methods 0.000 description 5
- 238000004891 communication Methods 0.000 description 4
- 238000004590 computer program Methods 0.000 description 4
- 238000005516 engineering process Methods 0.000 description 4
- 230000007246 mechanism Effects 0.000 description 4
- 238000012986 modification Methods 0.000 description 3
- 230000004048 modification Effects 0.000 description 3
- 230000002159 abnormal effect Effects 0.000 description 2
- 230000003993 interaction Effects 0.000 description 2
- 239000004973 liquid crystal related substance Substances 0.000 description 2
- 238000012544 monitoring process Methods 0.000 description 2
- 238000013459 approach Methods 0.000 description 1
- 230000005540 biological transmission Effects 0.000 description 1
- 230000001413 cellular effect Effects 0.000 description 1
- 238000010276 construction Methods 0.000 description 1
- 238000013500 data storage Methods 0.000 description 1
- 238000013461 design Methods 0.000 description 1
- 230000002708 enhancing effect Effects 0.000 description 1
- 238000010295 mobile communication Methods 0.000 description 1
- 230000003287 optical effect Effects 0.000 description 1
- 230000008520 organization Effects 0.000 description 1
- 230000001151 other effect Effects 0.000 description 1
- 238000007789 sealing Methods 0.000 description 1
- 230000001953 sensory effect Effects 0.000 description 1
- 238000006467 substitution reaction Methods 0.000 description 1
- 230000000007 visual effect Effects 0.000 description 1
Classifications
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L9/00—Cryptographic mechanisms or cryptographic arrangements for secret or secure communications; Network security protocols
- H04L9/32—Cryptographic mechanisms or cryptographic arrangements for secret or secure communications; Network security protocols including means for verifying the identity or authority of a user of the system or for message authentication, e.g. authorization, entity authentication, data integrity or data verification, non-repudiation, key authentication or verification of credentials
- H04L9/3297—Cryptographic mechanisms or cryptographic arrangements for secret or secure communications; Network security protocols including means for verifying the identity or authority of a user of the system or for message authentication, e.g. authorization, entity authentication, data integrity or data verification, non-repudiation, key authentication or verification of credentials involving time stamps, e.g. generation of time stamps
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L67/00—Network arrangements or protocols for supporting network services or applications
- H04L67/01—Protocols
- H04L67/10—Protocols in which an application is distributed across nodes in the network
- H04L67/104—Peer-to-peer [P2P] networks
- H04L67/1059—Inter-group management mechanisms, e.g. splitting, merging or interconnection of groups
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L67/00—Network arrangements or protocols for supporting network services or applications
- H04L67/01—Protocols
- H04L67/10—Protocols in which an application is distributed across nodes in the network
- H04L67/1097—Protocols in which an application is distributed across nodes in the network for distributed storage of data in networks, e.g. transport arrangements for network file system [NFS], storage area networks [SAN] or network attached storage [NAS]
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L9/00—Cryptographic mechanisms or cryptographic arrangements for secret or secure communications; Network security protocols
- H04L9/50—Cryptographic mechanisms or cryptographic arrangements for secret or secure communications; Network security protocols using hash chains, e.g. blockchains or hash trees
Landscapes
- Engineering & Computer Science (AREA)
- Computer Networks & Wireless Communication (AREA)
- Signal Processing (AREA)
- Computer Security & Cryptography (AREA)
- Financial Or Insurance-Related Operations Such As Payment And Settlement (AREA)
Abstract
本申请公开了一种区块链的事务验证方法、装置、设备和介质,涉及区块链技术领域。该方法包括:获取执行链节点向验证链网络发起的记录事务请求,所述记录事务请求中携带有所述执行链中的执行链区块信息和执行链事务信息;执行所述记录事务请求,以将所述执行链区块信息和执行链事务信息在验证链中进行上链存储;获取向验证链网络发起的验证事务请求,所述验证事务请求中携带有待验证执行链事务信息;执行所述验证事务请求,以根据所述验证链中记录的执行链区块信息和执行链事务信息,对所述待验证执行链事务信息进行验证。本实施例能够有效提高执行链的公信力,且提供便捷的事务验证方式。
Description
技术领域
本申请实施例涉及计算机技术领域,具体涉及区块链技术。
背景技术
区块链是分布式数据存储、点对点传输、共识机制、加密算法等计算机技术的新型应用模式。按照区块链规模和组织方式来区分,大致可分为公链、联盟链和私有链。
目前仍然处于区块链应用的早期阶段,大量的联盟链和私有链存在,但联盟链和私有链,一般是有一个或数个机构所提供的区块链节点来组建的网络,且区块链的账户权限也是受限的,所以存在数据封闭性,难以让外部用户相信其可信性。
发明内容
本申请实施例一种区块链的资源流通监控方法、装置、设备和介质,以增强对区块链中资源流通的风险监控能力。
第一方面,本申请实施例公开了一种区块链的事务验证方法,由验证链节点执行,所述方法包括:
获取执行链节点向验证链网络发起的记录事务请求,所述记录事务请求中携带有所述执行链中的执行链区块信息和执行链事务信息;
执行所述记录事务请求,以将所述执行链区块信息和执行链事务信息在验证链中进行上链存储;
获取向验证链网络发起的验证事务请求,所述验证事务请求中携带有待验证执行链事务信息;
执行所述验证事务请求,以根据所述验证链中记录的执行链区块信息和执行链事务信息,对所述待验证执行链事务信息进行验证。
上述申请中的一个实施例具有如下优点或有益效果:通过跨链技术来提高了链的信用。具体通过在验证链上来存储执行链的区块和事务信息,并提供直接的事务验证功能,从而提供了执行链的信用,也简化了验证过程。通过这种存证机制,联盟网络和私有网络也具备了和开放的公链网络一样的公信力。
另外,根据本申请上述实施例的区块链的事务验证方法,还可以具有如下附加的技术特征:
可选的,所述执行链区块信息包括所述执行链中区块的区块标识、出块时间和出块节点标识;
所述执行链事务信息包括所述执行链中区块内事务数据的梅克尔树根和事务标识列表。
可选的,所述待验证执行链事务信息包括事务标识,则执行所述验证事务请求,以根据所述验证链中记录的执行链区块信息和执行链事务信息,对所述待验证执行链事务信息进行验证包括:
执行所述验证事务请求,以根据所述待验证执行链事务标识,在所述验证链中记录的事务标识列表中进行查找;
如果所述事务标识列表中存在所述待验证执行链事务标识,则确定存在对应的区块,确定验证结果为通过验证。
上述申请中的一个实施例具有如下优点或有益效果,通过确定给待验证事务是否存在于执行链上报的区块中来确定事务的有效性,快捷直接。
可选的,确定存在对应的区块之后,还包括:
从所述待验证执行事务信息中获取事务提交时间;
如果所述事务提交时间与验证链中记录的出块时间匹配,则确定验证结果为通过验证。
上述申请中的一个实施例具有如下优点或有益效果,进一步验证事务提交时间和出块时间的匹配度,避免执行链未及时执行该事务请求的情况出现。
可选的,确定存在对应的区块之后,确定验证结果为通过验证之前,还包括:
从所述待验证执行事务信息中获取事务请求内容;
根据所述事务请求内容计算事务哈希,作为事务标识;
根据所述验证链中记录的事务标识列表重建梅克尔树;
如果重建的梅克尔树的根与记录的梅克尔树的根匹配,则验证结果为验证通过。
上述申请中的一个实施例具有如下优点或有益效果,通过重建梅克尔树,能够在验证链对待验证事务的实际内容进行全面验证。
可选的,执行所述记录事务请求的过程中,还包括:
获取可信时间戳,若当前获取的可信时间戳与所述执行链区块信息中的出块时间不匹配,则拒绝执行所述执行链区块信息的上链操作。
上述申请中的一个实施例具有如下优点或有益效果,通过验证执行链的出块时间,保证了执行链对出块信息的及时上报。
可选的,执行所述记录事务请求的过程中,还包括:
根据所述执行链区块信息的区块标识和所述执行链事务信息中的事务标识列表,建立所述区块标识与所述事务标识列表之间的索引,并作为所述记录事务请求的事务数据上链存储。
可选的,所述记录事务请求的事务数据以键值对形式存储,其中,所述执行链区块信息中的区块标识存储于键域中,所述执行链区块信息中的其他信息和执行链事务信息存储于值域中。
可选的,执行所述记录事务请求的过程中,还包括:
获取所述执行链的链标识,作为所述记录事务请求的事务数据上链存储。
可选的,获取向验证链网络发起的验证事务请求包括:
获取执行链节点向验证链网络发起的验证事务请求;或
获取用户通过验证链节点向验证链网络发起的验证事务请求。
上述申请中的一个实施例具有如下优点或有益效果,对事务的验证,可以由执行链发起,也允许用户直接发起,提供了多种有效途径,兼顾了验证的便利和公信力。
可选的,所述方法基于区块链中部署的链存证智能合约实现。
上述申请中的一个实施例具有如下优点或有益效果,记录事务请求和验证事务请求均可以通过链上的智能合约方式来实现,进一步提高了验证链的处理能力,以及事务处理的可追溯力度。
可选的,所述执行链为私有链或联盟链,所述验证链为公链。
第二方面,本申请实施例还提供了一种区块链的事务验证装置,配置于验证链节点中,所述装置包括:
记录请求获取模块,用于获取执行链节点向验证链网络发起的记录事务请求,所述记录事务请求中携带有所述执行链中的执行链区块信息和执行链事务信息;
记录请求执行模块,用于执行所述记录事务请求,以将所述执行链区块信息和执行链事务信息在验证链中进行上链存储;
验证请求获取模块,用于获取向验证链网络发起的验证事务请求,所述验证事务请求中携带有待验证执行链事务信息;
验证请求执行模块,用于执行所述验证事务请求,以根据所述验证链中记录的执行链区块信息和执行链事务信息,对所述待验证执行链事务信息进行验证。
第三方面,本申请实施例还提供了一种电子设备,包括:
至少一个处理器;以及
与所述至少一个处理器通信连接的存储器;其中,
所述存储器存储有可被所述至少一个处理器执行的指令,所述指令被所述至少一个处理器执行,以使所述至少一个处理器能够执行本申请第一方面实施例所提供的区块链的事务验证方法。
第四方面,本申请实施例还提供了一种存储有计算机指令的非瞬时计算机可读存储介质,所述计算机指令用于使所述计算机执行本申请第一方面实施例所提供的区块链的事务验证方法。
上述可选方式所具有的其他效果将在下文中结合具体实施例加以说明。
附图说明
附图用于更好地理解本方案,不构成对本申请的限定。其中:
图1为本申请实施例一提供的一种区块链的事务验证方法的流程图;
图2A为本申请实施例二提供的一种区块链的事务验证方法的流程图;
图2B为本申请实施例所适用的区块链示意图;
图3为本申请实施例三提供的一种区块链的事务验证装置的结构示意图;
图4是可以实现本申请实施例的电子设备的框图。
具体实施方式
以下结合附图对本申请的示范性实施例做出说明,其中包括本申请实施例的各种细节以助于理解,应当将它们认为仅仅是示范性的。因此,本领域普通技术人员应当认识到,可以对这里描述的实施例做出各种改变和修改,而不会背离本申请的范围和精神。同样,为了清楚和简明,以下的描述中省略了对公知功能和结构的描述。
在区块链的各种形态中,私有链和联盟链由于其数据封闭的程度,所以其信用会受到质疑。而公链为开放链,任何用户都可提供电子设备作为区块链节点来加入网络,任何用户都可以注册为区块链账户来访问区块链。由于公链数据完全公开,所有人都可以访问,因此具备最高的公信力。本案提供一种技术方案,能利用公链的公信力增强联盟链和私有链的信用。
实施例一
图1为本申请实施例一提供的一种区块链的事务验证方法的流程图。在本实施例中,适用于通过验证链对执行链的区块和事务信息进行存证,且能够提供对执行链中事务请求进行验证的情况。
本申请实施例所适用的区块链网络,包括至少一条验证链和至少一条执行链。执行链和验证链均为区块链,可部署于多个节点。同一电子设备可部署一条或多条区块链的数据,以参与各条区块链的运行。优选是,执行链为联盟链或私有链,验证链优选为公链,从而使得验证链具备较高的公信力。
本申请实施例由验证链节点执行,该验证链节点配置有区块链的事务验证装置,该装置可以采用软件和/或硬件的方式来实现。
如图1所示,所述方法包括:
S110、获取执行链节点向验证链网络发起的记录事务请求,所述记录事务请求中携带有所述执行链中的执行链区块信息和执行链事务信息;
其中,记录事务请求由执行链节点来发起,可以是部署有执行链数据点的本机节点,也可以是其他执行链节点发送的,优选是执行链的当前出块节点发送的。
可选的,当执行链的出块节点产生当前区块后,将当前区块的执行链区块信息和执行链事务信息,基于验证链的部署数据,形成一记录事务请求发起。具体可基于验证链节点中部署的链存证智能合约来发起记录事务请求。
记录事务请求中携带的所述执行链中的执行链区块信息和执行链事务信息,用于表示执行链中区块和区块中事务的信息。具体的,所述执行链区块信息可选的包括所述执行链中区块的区块标识、出块时间和出块节点标识;所述执行链事务信息可选的包括所述执行链中区块内事务数据的梅克尔树根和事务标识列表。本领域技术人员可以理解,上述各项信息可以根据存证需要独立采用或任意结合采用,也可以包括其他需要存证的信息。
S120、执行所述记录事务请求,以将所述执行链区块信息和执行链事务信息在验证链中进行上链存储;
验证链节点获取该记录事务请求之后执行,例如可以通过运行链存证智能合约来执行该记录事务请求,将所述执行链区块信息和执行链事务信息在验证链中进行上链存储。
可选的,在执行过程中,还可以包括:获取所述执行链的链标识,作为所述记录事务请求的事务数据上链存储。执行链的链标识可在记录事务请求中携带,例如可通过区块标识中的字段来确定其所属执行链。从而,在验证链中,可以以执行链为单位来组织存证数据。
记录事务请求的事务数据优选是以键值对形式存储,其中,所述执行链区块信息中的区块标识存储于键域中,所述执行链区块信息中的其他信息和执行链事务信息存储于值域中。
例如,执行链的每个区块可作为一个数据对象进行键值对(KV)形式的存储,即一条KV。例如,私有网络A中的SA链,在链存证智能合约中存储以”A_SA_+块高度”作为键域(key)进行存储,将块ID和出块时间、块内交易的Merkle树根和事务标识列表等信息作为值域(value)进行存储。
上述操作中,在执行所述记录事务请求的过程中,优选是还包括:
获取可信时间戳,若当前获取的可信时间戳与所述执行链区块信息中的出块时间不匹配,则拒绝执行所述执行链区块信息的上链操作。
可信时间戳可以通过向认证的授时机构请求来获取。可选是在接收到记录事务请求时获取,如果执行链上报的出块时间与获得记录事务请求的时间不匹配,则说明可能上报的区块信息是虚假的,或超时很久才上报,这样可视为异常,从而拒绝执行记录事务请求的上链操作。可信时间戳与出块时间之间的误差小于设定时间阈值视为匹配。
S130、获取向验证链网络发起的验证事务请求,所述验证事务请求中携带有待验证执行链事务信息;
验证事务请求用于对执行链中的事务进行验证。可选的,获取向验证链网络发起的验证事务请求可以有不同的途径,具体是:
获取执行链节点向验证链网络发起的验证事务请求;或
获取用户通过验证链节点向验证链网络发起的验证事务请求。
具体而言,执行链节点在接收到用户在执行链的事务查询请求时,可以直接给用户反馈,为了体现公信力,可以进一步向验证链发起验证事务请求,以获取验证链反馈的事务验证结果。执行链节点可基于部署在验证链中的链存证智能合约来发起该验证事务请求,或者基于验证链部署的系统级验证接口来发起验证事务请求。
另一种验证事务请求的来源是,用户可直接发起。当用户在执行链中处理了事务之后,当希望能验证该事务的正确性时,则可以直接向验证链发起验证事务请求,具体也可以基于验证链上部署的链存证智能合约来发起或基于系统级验证接口来发起。
S140、执行所述验证事务请求,以根据所述验证链中记录的执行链区块信息和执行链事务信息,对所述待验证执行链事务信息进行验证。
在执行所述验证事务请求的过程中,完成对事务的验证。具体的,如果所述待验证执行链事务信息包括事务标识(TXID),则执行所述验证事务请求,以根据所述验证链中记录的执行链区块信息和执行链事务信息,对所述待验证执行链事务信息进行验证具体包括:
执行所述验证事务请求,以根据所述待验证执行链事务标识,在所述验证链中记录的事务标识列表中进行查找;
如果所述事务标识列表中存在所述待验证执行链事务标识,则确定存在对应的区块,确定验证结果为通过验证。
上述操作表明,若执行链在处理该事务时,打包到区块中并存证到验证链中,则表明该事务被执行链有效的处理并上链存储了,表明验证通过。
本申请实施例的技术方案,通过跨链技术来提高了链的信用。具体通过在验证链上来存储执行链的区块和事务信息,并提供直接的事务验证功能,从而提供了执行链的信用,也简化了验证过程。通过这种存证机制,联盟网络和私有网络也具备了和开放的公链网络一样的公信力。可选的,在验证链中存储的是执行链的区块信息和事务信息,而不会存储实际的事务数据,所以不会在验证链中泄露诸如联盟链和私有链等执行链的链上数据。
实施例二
图2A为本申请实施例二提供的一种区块链的事务验证方法的流程图,本实施例以前述实施例为基础,提供了优化的验证方式。具体的,如图2A所示,该方法包括:
S201、获取执行链节点向验证链网络发起的记录事务请求,所述记录事务请求中携带有所述执行链中的执行链区块信息和执行链事务信息;
优选的,执行链区块信息包括区块标识、出块时间和出块节点标识。执行链事务信息包括区块内事务数据的梅克尔树根和事务标识列表。事务标识实际为该事务数据的哈希。
S202、执行所述记录事务请求,以将所述执行链区块信息和执行链事务信息在验证链中进行上链存储;
在执行所述记录事务请求的过程中,可选的还包括:
根据所述执行链区块信息的区块标识和所述执行链事务信息中的事务标识列表,建立所述区块标识与所述事务标识列表之间的索引,并作为所述记录事务请求的事务数据上链存储。
为了方便的根据事务标识检索到对应的区块标识,可建立有效的索引关系,方便查找。该索引建立过程可存储于验证链节点本地数据中,也可以通过链存证智能合约完成并上链存储。
S203、获取向验证链网络发起的验证事务请求,所述验证事务请求中携带有待验证执行链事务信息;
S204、执行所述验证事务请求,以根据所述待验证执行链事务标识,在所述验证链中记录的事务标识列表中进行查找;
S205、所述事务标识列表中是否存在所述待验证执行链事务标识,若是,则确定存在对应的区块,执行步骤S206,否则,确定验证结果为不通过验证;
如前所述,当根据事务标识,根据索引查找到对应的区块之后,还可以进一步的:
S206、从所述待验证执行事务信息中获取事务提交时间;
S207、所述事务提交时间与验证链中记录的出块时间是否匹配,若是,则执行步骤S208,否则确定验证结果为不通过验证;
具体是,当用户发起验证事务请求时,还提供曾经向执行链提交事务请求时的时间,即事务提交时间。将该事务提交时间一并作为待验证执行链事务信息提供给验证链节点。验证链节点如果确定事务提交时间与出块时间的时间差在预设时间阈值范围内,则表明时间匹配,执行链及时处理了该事务,否则执行链可能未及时处理,视为出现了异常。相应的,如果所述事务提交时间与验证链中记录的出块时间不匹配,则验证结果为不通过验证。
优选是,本申请实施例不限于验证事务请求的存在,还可以进一步验证事务请求的原始内容是否有效。则在确定存在对应的区块之后,确定验证结果为通过验证之前,还包括:
S208、从所述待验证执行事务信息中获取事务请求内容;
S209、根据所述事务请求内容计算事务哈希,作为事务标识;
S210、根据所述验证链中记录的事务标识列表重建梅克尔树;
根据执行链上报的事务标识列表,可获知该区块中每个事务的标识,即事务哈希,也可获知事务顺序,从而可据此重建梅克尔树。
S211、重建的梅克尔树的根与记录的梅克尔树的根是否匹配,若是,则验证结果为验证通过,否则验证结果为不通过验证。
通过上述过程,可选的对事务是否存在于区块内,事务提交时间是否匹配于出块时间,以及事务请求内容是否与区块内事务请求内容一致,进行有效验证。
本申请实施例尤为适用于私有链和联盟链向公链进行存证的操作场景。具体如2B所示,联盟链A包括区块A0、A1、A2和A3,私有链B包括区块B0、B1、B2和B3,均作为执行链。开放公链作为验证链,包括区块X0、X1、X2和X3。在执行链出块的过程中,可发起记录事务请求,将区块信息和事务信息上链存储到开放的验证链中。
实施例三
图3为本申请实施例三提供的一种区块链的事务验证装置的结构示意图。该装置可采用软件和/或硬件的方式实现,配置于作为验证链节点的电子设备中。该装置包括:记录请求获取模块310、记录请求执行模块320、验证请求获取模块330和验证请求执行模块340。
其中,记录请求获取模块310,用于获取执行链节点向验证链网络发起的记录事务请求,所述记录事务请求中携带有所述执行链中的执行链区块信息和执行链事务信息;
记录请求执行模块320,用于执行所述记录事务请求,以将所述执行链区块信息和执行链事务信息在验证链中进行上链存储;
验证请求获取模块330,用于获取向验证链网络发起的验证事务请求,所述验证事务请求中携带有待验证执行链事务信息;
验证请求执行模块340,用于执行所述验证事务请求,以根据所述验证链中记录的执行链区块信息和执行链事务信息,对所述待验证执行链事务信息进行验证。
本申请实施例的技术方案,通过跨链技术来提高了链的信用。具体通过在验证链上来存储执行链的区块和事务信息,并提供直接的事务验证功能,从而提供了执行链的信用,也简化了验证过程。通过这种存证机制,联盟网络和私有网络也具备了和开放的公链网络一样的公信力。
可选的,所述执行链区块信息包括所述执行链中区块的区块标识、出块时间和出块节点标识;
所述执行链事务信息包括所述执行链中区块内事务数据的梅克尔树根和事务标识列表。
可选的,所述待验证执行链事务信息包括事务标识,则所述验证请求执行模块具体用于:
执行所述验证事务请求,以根据所述待验证执行链事务标识,在所述验证链中记录的事务标识列表中进行查找;
如果所述事务标识列表中存在所述待验证执行链事务标识,则确定存在对应的区块,确定验证结果为通过验证。
可选的,所述验证请求执行模块还具体用于,确定存在对应的区块之后,从所述待验证执行事务信息中获取事务提交时间;如果所述事务提交时间与验证链中记录的出块时间匹配,则确定验证结果为通过验证。
可选的,所述验证请求执行模块还具体用于,确定存在对应的区块之后,确定验证结果为通过验证之前,从所述待验证执行事务信息中获取事务请求内容;根据所述事务请求内容计算事务哈希,作为事务标识;根据所述验证链中记录的事务标识列表重建梅克尔树;如果重建的梅克尔树的根与记录的梅克尔树的根匹配,则验证结果为验证通过。
可选的,所述记录请求执行模块还具体用于,执行所述记录事务请求的过程中,获取可信时间戳,若当前获取的可信时间戳与所述执行链区块信息中的出块时间不匹配,则拒绝执行所述执行链区块信息的上链操作。
可选的,所述记录请求执行模块还具体用于,执行所述记录事务请求的过程中,根据所述执行链区块信息的区块标识和所述执行链事务信息中的事务标识列表,建立所述区块标识与所述事务标识列表之间的索引,并作为所述记录事务请求的事务数据上链存储。
可选的,所述记录事务请求的事务数据以键值对形式存储,其中,所述执行链区块信息中的区块标识存储于键域中,所述执行链区块信息中的其他信息和执行链事务信息存储于值域中。
可选的,所述记录请求执行模块还具体用于,执行所述记录事务请求的过程中,获取所述执行链的链标识,作为所述记录事务请求的事务数据上链存储。
可选的,所述验证请求获取模块具体用于,获取执行链节点向验证链网络发起的验证事务请求;或获取用户通过验证链节点向验证链网络发起的验证事务请求。
可选的,验证事务请求和记录事务请求,基于区块链中部署的链存证智能合约实现。
可选的,所述执行链为私有链或联盟链,所述验证链为公链。
根据本申请的实施例,本申请还提供了一种电子设备和一种可读存储介质。
如图4所示,是根据本申请实施例的区块链的事务验证方法的电子设备的框图。电子设备旨在表示各种形式的数字计算机,诸如,膝上型计算机、台式计算机、工作台、个人数字助理、服务器、刀片式服务器、大型计算机、和其它适合的计算机。电子设备还可以表示各种形式的移动装置,诸如,个人数字处理、蜂窝电话、智能电话、可穿戴设备和其它类似的计算装置。本文所示的部件、它们的连接和关系、以及它们的功能仅仅作为示例,并且不意在限制本文中描述的和/或者要求的本申请的实现。
如图4所示,该电子设备包括:一个或多个处理器401、存储器402,以及用于连接各部件的接口,包括高速接口和低速接口。各个部件利用不同的总线互相连接,并且可以被安装在公共主板上或者根据需要以其它方式安装。处理器可以对在电子设备内执行的指令进行处理,包括存储在存储器中或者存储器上以在外部输入/输出装置(诸如,耦合至接口的显示设备)上显示GUI的图形信息的指令。在其它实施方式中,若需要,可以将多个处理器和/或多条总线与多个存储器和多个存储器一起使用。同样,可以连接多个电子设备,各个设备提供部分必要的操作(例如,作为服务器阵列、一组刀片式服务器、或者多处理器系统)。图4中以一个处理器401为例。
存储器402即为本申请所提供的非瞬时计算机可读存储介质。其中,所述存储器存储有可由至少一个处理器执行的指令,以使所述至少一个处理器执行本申请所提供的区块链的事务验证方法。本申请的非瞬时计算机可读存储介质存储计算机指令,该计算机指令用于使计算机执行本申请所提供的区块链的事务验证方法。
存储器402作为一种非瞬时计算机可读存储介质,可用于存储非瞬时软件程序、非瞬时计算机可执行程序以及模块,如本申请实施例中的区块链的事务验证方法对应的程序指令/模块(例如,附图3所示的记录请求获取模块310、记录请求执行模块320、验证请求获取模块330和验证请求执行模块340)。处理器401通过运行存储在存储器402中的非瞬时软件程序、指令以及模块,从而执行服务器的各种功能应用以及数据处理,即实现上述方法实施例中的区块链的事务验证方法。
存储器402可以包括存储程序区和存储数据区,其中,存储程序区可存储操作系统、至少一个功能所需要的应用程序;存储数据区可存储根据区块链的事务验证电子设备的使用所创建的数据等。此外,存储器402可以包括高速随机存取存储器,还可以包括非瞬时存储器,例如至少一个磁盘存储器件、闪存器件、或其他非瞬时固态存储器件。在一些实施例中,存储器402可选包括相对于处理器401远程设置的存储器,这些远程存储器可以通过网络连接至区块链的事务验证电子设备。上述网络的实例包括但不限于互联网、企业内部网、局域网、移动通信网及其组合。
区块链的事务验证方法的电子设备还可以包括:输入装置403和输出装置404。处理器401、存储器402、输入装置403和输出装置404可以通过总线或者其他方式连接,图4中以通过总线连接为例。
输入装置403可接收输入的数字或字符信息,以及产生与区块链的事务验证电子设备的用户设置以及功能控制有关的键信号输入,例如触摸屏、小键盘、鼠标、轨迹板、触摸板、指示杆、一个或者多个鼠标按钮、轨迹球、操纵杆等输入装置。输出装置404可以包括显示设备、辅助照明装置(例如,LED)和触觉反馈装置(例如,振动电机)等。该显示设备可以包括但不限于,液晶显示器(LCD)、发光二极管(LED)显示器和等离子体显示器。在一些实施方式中,显示设备可以是触摸屏。
此处描述的系统和技术的各种实施方式可以在数字电子电路系统、集成电路系统、专用ASIC(专用集成电路)、计算机硬件、固件、软件、和/或它们的组合中实现。这些各种实施方式可以包括:实施在一个或者多个计算机程序中,该一个或者多个计算机程序可在包括至少一个可编程处理器的可编程系统上执行和/或解释,该可编程处理器可以是专用或者通用可编程处理器,可以从存储系统、至少一个输入装置、和至少一个输出装置接收数据和指令,并且将数据和指令传输至该存储系统、该至少一个输入装置、和该至少一个输出装置。
这些计算程序(也称作程序、软件、软件应用、或者代码)包括可编程处理器的机器指令,并且可以利用高级过程和/或面向对象的编程语言、和/或汇编/机器语言来实施这些计算程序。如本文使用的,术语“机器可读介质”和“计算机可读介质”指的是用于将机器指令和/或数据提供给可编程处理器的任何计算机程序产品、设备、和/或装置(例如,磁盘、光盘、存储器、可编程逻辑装置(PLD)),包括,接收作为机器可读信号的机器指令的机器可读介质。术语“机器可读信号”指的是用于将机器指令和/或数据提供给可编程处理器的任何信号。
为了提供与用户的交互,可以在计算机上实施此处描述的系统和技术,该计算机具有:用于向用户显示信息的显示装置(例如,CRT(阴极射线管)或者LCD(液晶显示器)监视器);以及键盘和指向装置(例如,鼠标或者轨迹球),用户可以通过该键盘和该指向装置来将输入提供给计算机。其它种类的装置还可以用于提供与用户的交互;例如,提供给用户的反馈可以是任何形式的传感反馈(例如,视觉反馈、听觉反馈、或者触觉反馈);并且可以用任何形式(包括声输入、语音输入或者、触觉输入)来接收来自用户的输入。
可以将此处描述的系统和技术实施在包括后台部件的计算系统(例如,作为数据服务器)、或者包括中间件部件的计算系统(例如,应用服务器)、或者包括前端部件的计算系统(例如,具有图形用户界面或者网络浏览器的用户计算机,用户可以通过该图形用户界面或者该网络浏览器来与此处描述的系统和技术的实施方式交互)、或者包括这种后台部件、中间件部件、或者前端部件的任何组合的计算系统中。可以通过任何形式或者介质的数字数据通信(例如,通信网络)来将系统的部件相互连接。通信网络的示例包括:局域网(LAN)、广域网(WAN)、互联网和区块链网络。
计算机系统可以包括客户端和服务器。客户端和服务器一般远离彼此并且通常通过通信网络进行交互。通过在相应的计算机上运行并且彼此具有客户端-服务器关系的计算机程序来产生客户端和服务器的关系。
应该理解,可以使用上面所示的各种形式的流程,重新排序、增加或删除步骤。例如,本发申请中记载的各步骤可以并行地执行也可以顺序地执行也可以不同的次序执行,只要能够实现本申请公开的技术方案所期望的结果,本文在此不进行限制。
上述具体实施方式,并不构成对本申请保护范围的限制。本领域技术人员应该明白的是,根据设计要求和其他因素,可以进行各种修改、组合、子组合和替代。任何在本申请的精神和原则之内所作的修改、等同替换和改进等,均应包含在本申请保护范围之内。
Claims (11)
1.一种区块链的事务验证方法,其特征在于,由验证链节点执行,所述方法包括:
获取执行链节点向验证链网络发起的记录事务请求,所述记录事务请求中携带有所述执行链中的执行链区块信息和执行链事务信息;
执行所述记录事务请求,以将所述执行链区块信息和执行链事务信息在验证链中进行上链存储;
获取向验证链网络发起的验证事务请求,所述验证事务请求中携带有待验证执行链事务信息;所述验证事务请求由所述验证链网络发起;
执行所述验证事务请求,以根据所述验证链中记录的执行链区块信息和执行链事务信息,对所述待验证执行链事务信息进行验证;所述执行链区块信息包括所述执行链中区块的区块标识、出块时间和出块节点标识;所述执行链事务信息包括所述执行链中区块内事务数据的梅克尔树根和事务标识列表;
其中,执行所述记录事务请求的过程中,还包括:
获取可信时间戳,若当前获取的可信时间戳与所述执行链区块信息中的出块时间不匹配,则拒绝执行所述执行链区块信息的上链操作;
其中,执行所述记录事务请求的过程中,还包括:
根据所述执行链区块信息的区块标识和所述执行链事务信息中的事务标识列表,建立所述区块标识与所述事务标识列表之间的索引,并作为所述记录事务请求的事务数据上链存储;
所述记录事务请求的事务数据以键值对形式存储,其中,所述执行链区块信息中的区块标识存储于键域中,所述执行链区块信息中的其他信息和执行链事务信息存储于值域中。
2.根据权利要求1所述的方法,其特征在于,所述待验证执行链事务信息包括事务标识,则执行所述验证事务请求,以根据所述验证链中记录的执行链区块信息和执行链事务信息,对所述待验证执行链事务信息进行验证包括:
执行所述验证事务请求,以根据所述待验证执行链事务标识,在所述验证链中记录的事务标识列表中进行查找;
如果所述事务标识列表中存在所述待验证执行链事务标识,则确定存在对应的区块,确定验证结果为通过验证。
3.根据权利要求2所述的方法,其特征在于,确定存在对应的区块之后,还包括:
从所述待验证执行事务信息中获取事务提交时间;
如果所述事务提交时间与验证链中记录的出块时间匹配,则确定验证结果为通过验证。
4.根据权利要求2所述的方法,其特征在于,确定存在对应的区块之后,确定验证结果为通过验证之前,还包括:
从所述待验证执行事务信息中获取事务请求内容;
根据所述事务请求内容计算事务哈希,作为事务标识;
根据所述验证链中记录的事务标识列表重建梅克尔树;
如果重建的梅克尔树的根与记录的梅克尔树的根匹配,则验证结果为验证通过。
5.根据权利要求1所述的方法,其特征在于,执行所述记录事务请求的过程中,还包括:
获取所述执行链的链标识,作为所述记录事务请求的事务数据上链存储。
6.根据权利要求1所述的方法,其特征在于,获取向验证链网络发起的验证事务请求包括:
获取执行链节点向验证链网络发起的验证事务请求;或
获取用户通过验证链节点向验证链网络发起的验证事务请求。
7.根据权利要求1-6任一所述的方法,其特征在于,所述方法基于区块链中部署的链存证智能合约实现。
8.根据权利要求1-6任一所述的方法,其特征在于:所述执行链为私有链或联盟链,所述验证链为公链。
9.一种区块链的事务验证装置,其特征在于,配置于验证链节点中,所述装置包括:
记录请求获取模块,用于获取执行链节点向验证链网络发起的记录事务请求,所述记录事务请求中携带有所述执行链中的执行链区块信息和执行链事务信息;
记录请求执行模块,用于执行所述记录事务请求,以将所述执行链区块信息和执行链事务信息在验证链中进行上链存储;
验证请求获取模块,用于获取向验证链网络发起的验证事务请求,所述验证事务请求中携带有待验证执行链事务信息;所述验证事务请求由所述验证链网络发起;
验证请求执行模块,用于执行所述验证事务请求,以根据所述验证链中记录的执行链区块信息和执行链事务信息,对所述待验证执行链事务信息进行验证;
其中,所述执行链区块信息包括所述执行链中区块的区块标识、出块时间和出块节点标识;
所述执行链事务信息包括所述执行链中区块内事务数据的梅克尔树根和事务标识列表;
其中,所述记录请求执行模块还具体用于,执行所述记录事务请求的过程中,获取可信时间戳,若当前获取的可信时间戳与所述执行链区块信息中的出块时间不匹配,则拒绝执行所述执行链区块信息的上链操作;
其中,所述记录请求执行模块还具体用于,执行所述记录事务请求的过程中,根据所述执行链区块信息的区块标识和所述执行链事务信息中的事务标识列表,建立所述区块标识与所述事务标识列表之间的索引,并作为所述记录事务请求的事务数据上链存储;
所述记录事务请求的事务数据以键值对形式存储,其中,所述执行链区块信息中的区块标识存储于键域中,所述执行链区块信息中的其他信息和执行链事务信息存储于值域中。
10.一种电子设备,其特征在于,包括:
至少一个处理器;以及
与所述至少一个处理器通信连接的存储器;其中,
所述存储器存储有可被所述至少一个处理器执行的指令,所述指令被所述至少一个处理器执行,以使所述至少一个处理器能够执行权利要求1-8中任一项所述的区块链的事务验证方法。
11.一种存储有计算机指令的非瞬时计算机可读存储介质,其特征在于,所述计算机指令用于使所述计算机执行权利要求1-8中任一项所述的区块链的事务验证方法。
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN202010113572.6A CN111342972B (zh) | 2020-02-24 | 2020-02-24 | 一种区块链的事务实现方法、装置、设备和介质 |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN202010113572.6A CN111342972B (zh) | 2020-02-24 | 2020-02-24 | 一种区块链的事务实现方法、装置、设备和介质 |
Publications (2)
Publication Number | Publication Date |
---|---|
CN111342972A CN111342972A (zh) | 2020-06-26 |
CN111342972B true CN111342972B (zh) | 2023-09-15 |
Family
ID=71185418
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
CN202010113572.6A Active CN111342972B (zh) | 2020-02-24 | 2020-02-24 | 一种区块链的事务实现方法、装置、设备和介质 |
Country Status (1)
Country | Link |
---|---|
CN (1) | CN111342972B (zh) |
Citations (12)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN109242456A (zh) * | 2018-09-04 | 2019-01-18 | 湖南宸瀚信息科技有限责任公司 | 区块链跨链交易方法、系统及存储介质 |
CN109345387A (zh) * | 2018-09-04 | 2019-02-15 | 湖南宸瀚信息科技有限责任公司 | 区块链跨链交易方法、跨链通信装置及存储介质 |
CN109471744A (zh) * | 2018-11-21 | 2019-03-15 | 北京蓝石环球区块链科技有限公司 | 基于区块链的主链加并行多子链系统架构 |
WO2019072312A2 (en) * | 2018-12-29 | 2019-04-18 | Alibaba Group Holding Limited | SYSTEM AND METHOD FOR DETECTING REJECTION ATTACK |
CN110033243A (zh) * | 2019-03-06 | 2019-07-19 | 华南师范大学 | 基于区块链智能合约的主链存证方法、系统及存储介质 |
CN110109930A (zh) * | 2019-05-15 | 2019-08-09 | 山东省计算中心(国家超级计算济南中心) | 基于区块链双链结构的政务数据存储、查询方法及系统 |
CN110598058A (zh) * | 2019-09-16 | 2019-12-20 | 百度在线网络技术(北京)有限公司 | 司法链的证据存证和处理方法、装置、设备和介质 |
CN110598452A (zh) * | 2019-09-19 | 2019-12-20 | 腾讯科技(深圳)有限公司 | 基于区块链的证据信息处理方法、装置、存储介质和设备 |
CN110609869A (zh) * | 2019-09-10 | 2019-12-24 | 连连银通电子支付有限公司 | 一种基于区块链的数据存储方法、相关设备及存储介质 |
CN110648227A (zh) * | 2019-08-05 | 2020-01-03 | 孟江华 | 一种通过链下结算的链上资产质押融资系统和方法 |
CN110690974A (zh) * | 2019-12-10 | 2020-01-14 | 腾讯科技(深圳)有限公司 | 基于区块链的数据验证方法、装置、设备及可读存储介质 |
CN110740044A (zh) * | 2019-10-30 | 2020-01-31 | 北京海益同展信息科技有限公司 | 数据处理方法、装置、系统和存储介质 |
-
2020
- 2020-02-24 CN CN202010113572.6A patent/CN111342972B/zh active Active
Patent Citations (12)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN109242456A (zh) * | 2018-09-04 | 2019-01-18 | 湖南宸瀚信息科技有限责任公司 | 区块链跨链交易方法、系统及存储介质 |
CN109345387A (zh) * | 2018-09-04 | 2019-02-15 | 湖南宸瀚信息科技有限责任公司 | 区块链跨链交易方法、跨链通信装置及存储介质 |
CN109471744A (zh) * | 2018-11-21 | 2019-03-15 | 北京蓝石环球区块链科技有限公司 | 基于区块链的主链加并行多子链系统架构 |
WO2019072312A2 (en) * | 2018-12-29 | 2019-04-18 | Alibaba Group Holding Limited | SYSTEM AND METHOD FOR DETECTING REJECTION ATTACK |
CN110033243A (zh) * | 2019-03-06 | 2019-07-19 | 华南师范大学 | 基于区块链智能合约的主链存证方法、系统及存储介质 |
CN110109930A (zh) * | 2019-05-15 | 2019-08-09 | 山东省计算中心(国家超级计算济南中心) | 基于区块链双链结构的政务数据存储、查询方法及系统 |
CN110648227A (zh) * | 2019-08-05 | 2020-01-03 | 孟江华 | 一种通过链下结算的链上资产质押融资系统和方法 |
CN110609869A (zh) * | 2019-09-10 | 2019-12-24 | 连连银通电子支付有限公司 | 一种基于区块链的数据存储方法、相关设备及存储介质 |
CN110598058A (zh) * | 2019-09-16 | 2019-12-20 | 百度在线网络技术(北京)有限公司 | 司法链的证据存证和处理方法、装置、设备和介质 |
CN110598452A (zh) * | 2019-09-19 | 2019-12-20 | 腾讯科技(深圳)有限公司 | 基于区块链的证据信息处理方法、装置、存储介质和设备 |
CN110740044A (zh) * | 2019-10-30 | 2020-01-31 | 北京海益同展信息科技有限公司 | 数据处理方法、装置、系统和存储介质 |
CN110690974A (zh) * | 2019-12-10 | 2020-01-14 | 腾讯科技(深圳)有限公司 | 基于区块链的数据验证方法、装置、设备及可读存储介质 |
Non-Patent Citations (2)
Title |
---|
An Authentication Scheme Using Identity-based Encryption & Blockchain;Beini Zhou等;《2018 IEEE Symposium on Computers and Communications (ISCC)》;全文 * |
基于联盟链的多链式区块链共识性能研究;孙一蓬;《 CNKI优秀硕士学位论文全文库》;全文 * |
Also Published As
Publication number | Publication date |
---|---|
CN111342972A (zh) | 2020-06-26 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
US11386076B2 (en) | Data processing method and apparatus based on blockchain network, electronic device, and storage medium | |
US11665000B2 (en) | Method and apparatus for processing privacy data of block chain, device, and storage medium | |
EP3639465B1 (en) | Improved hardware security module management | |
US10250594B2 (en) | Declarative techniques for transaction-specific authentication | |
US10616196B1 (en) | User authentication with multiple authentication sources and non-binary authentication decisions | |
CN111460429B (zh) | 基于可信执行环境的任务处理方法、装置、设备和介质 | |
US8990550B1 (en) | Methods and apparatus for securing communications between a node and a server based on hardware metadata gathered by an in-memory process | |
US10853353B2 (en) | Blockchain-enabled datasets shared across different database systems | |
CN110535970B (zh) | 司法链的证据存证和处理方法、装置、设备和介质 | |
CN111737365B (zh) | 存证处理方法、装置、设备和存储介质 | |
US20240104563A1 (en) | Hybrid identity as a service for decentralized browser based wallets | |
CN109995523B (zh) | 激活码管理方法及装置、激活码生成方法及装置 | |
CN111274591A (zh) | 一种访问Kubernetes集群的方法、装置、电子设备和介质 | |
US20140137248A1 (en) | Client Token Storage for Cross-Site Request Forgery Protection | |
US20220029983A1 (en) | System and method for automated customer verification | |
WO2022143298A1 (zh) | 基于区块链的数据处理方法和装置 | |
CN110795763A (zh) | 电子证照处理方法、查询方法、装置、设备、平台和介质 | |
CN111552934A (zh) | 数据库访问方法以及装置 | |
EP3970048A1 (en) | Systems and methods for non-parallelised mining on a proof-of-work blockchain network | |
US10198558B2 (en) | Data source security cluster | |
CN111342972B (zh) | 一种区块链的事务实现方法、装置、设备和介质 | |
CN111400743A (zh) | 基于区块链网络的事务处理方法、装置、电子设备和介质 | |
CN113609156B (zh) | 数据的查询与写入方法、装置、电子设备及可读存储介质 | |
US10033535B2 (en) | Multifaceted assertion directory system | |
CN110765210A (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 |