CN109118220A - 在分布式网络中用于处理事务的方法、装置及存储介质 - Google Patents
在分布式网络中用于处理事务的方法、装置及存储介质 Download PDFInfo
- Publication number
- CN109118220A CN109118220A CN201810875767.7A CN201810875767A CN109118220A CN 109118220 A CN109118220 A CN 109118220A CN 201810875767 A CN201810875767 A CN 201810875767A CN 109118220 A CN109118220 A CN 109118220A
- Authority
- CN
- China
- Prior art keywords
- affairs
- node
- transactions requests
- recipient
- data
- 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
Classifications
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06Q—INFORMATION AND COMMUNICATION TECHNOLOGY [ICT] SPECIALLY ADAPTED FOR ADMINISTRATIVE, COMMERCIAL, FINANCIAL, MANAGERIAL OR SUPERVISORY PURPOSES; SYSTEMS OR METHODS SPECIALLY ADAPTED FOR ADMINISTRATIVE, COMMERCIAL, FINANCIAL, MANAGERIAL OR SUPERVISORY PURPOSES, NOT OTHERWISE PROVIDED FOR
- G06Q20/00—Payment architectures, schemes or protocols
- G06Q20/38—Payment protocols; Details thereof
- G06Q20/389—Keeping log of transactions for guaranteeing non-repudiation of a transaction
-
- 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/46—Multiprogramming arrangements
- G06F9/466—Transaction processing
Abstract
本发明的实施例提供了在分布式网络中用于处理事务的方法,该分布式网络例如为区块链网络,该方法包括:事务发起方节点接收第一事务请求,其中,所述第一事务请求包括数字凭证标识信息;在所述事务发起方节点的本地账本中获取与所述数字凭证标识信息相关联的第一数据;基于所述第一数据获得所述第一事务请求的至少一个事务接收方节点的地址信息;以及基于所述地址信息向所述至少一个事务接收方节点转发所述第一事务请求。依据本发明所提出的方法通过所建立的事务请求在相关的分布式节点之间的转发机制能够获得不同的分布式节点上的与该事务请求相关联的响应。
Description
技术领域
本发明的实施例涉及分布式网络技术,更为具体地涉及一种在分布式网络中用于处理事务的方法、一种用于执行上述的在分布式网络中用于处理事务的方法的装置以及一种相应的计算机可读存储介质。
背景技术
分布式网络与中央控制式网络系统相对应,是一种新型的网络系统。在分布式网络中,每个节点彼此通信耦合,形成纵横交错的网状结构。
区块链作为分布式网络技术的一个分支,得到了广泛的讨论和研究。区块链是用分布式数据库识别、传播和记载信息的智能化对等网络,也称为价值互联网。区块链技术包括以块结构存储数据,使用密码学保证传输和访问安全等,其能够实现数据一致性存储、反篡改、去中心的技术体系。
智能合约是一种旨在以信息化方式传播、验证或执行合同的计算机协议,其能够表现为在区块链上准确运行的计算机程序。用户终端可通过使用智能合约进行交易、共享数据、建立信任、并由区块链技术的特性保障数据的存储、读取、执行整个过程透明可跟踪、不可篡改。
目前主流的分布式账本技术采用分布式存储模式,每个分布式节点保存相同备份,而且数据通过广播形式进行传播,每个节点获得相同的账本信息。
此外,由于每个分布式账本技术中的节点所存储的数据均包括与自身分布式节点并不相关的数据以及隐私数据。而数据隐私一般通过密码学技术进行保护,即每个分布式节点所保存的数据为加密后的数据,仅有授权获得密钥的节点可以解密并查看数据原文,而其它虽然保存有该部分数据但是未被授权获得密钥的节点则无法查看该数据原文。
发明内容
针对以上技术问题以及其他潜在的技术问题,本发明的实施例的第一方面提供了一种在分布式网络中用于处理事务的方法,所述方法包括:
事务发起方节点接收第一事务请求,其中,所述第一事务请求包括数字凭证标识信息;
在所述事务发起方节点的本地账本中获取与所述数字凭证标识信息相关联的第一数据;
基于所述第一数据获得所述第一事务请求的至少一个事务接收方节点的地址信息;以及
基于所述地址信息向所述至少一个事务接收方节点转发所述第一事务请求。
此外,本发明的实施例的第二方面提供了一种在分布式网络中用于处理事务的装置,所述装置包括:
处理器;以及
存储器,其用于存储指令,当所述指令执行时使得所述处理器执行以下操作:
事务发起方节点接收第一事务请求,其中,所述第一事务请求包括数字凭证标识信息;
在所述事务发起方节点的本地账本中获取与所述数字凭证标识信息相关联的第一数据;
基于所述第一数据获得所述第一事务请求的至少一个事务接收方节点的地址信息;以及
基于所述地址信息向所述至少一个事务接收方节点转发所述第一事务请求。
再者,本发明的实施例的第三方面提供了一种在分布式网络中用于处理事务的方法,所述方法包括:
事务接收方节点接收第一事务请求,其中,所述第一事务请求包括数字凭证标识信息;
在所述事务接收方节点的账本中获取与所述数字凭证标识信息相关联的第二数据;以及
将所述第二数据发送至所述第一事务请求的事务发起方节点,或者将所述第二数据发送至第一事务接收方节点,其中,所述第一事务接收方节点为向所述事务接收方节点发送所述第一事务请求的节点。
此外,本发明的实施例的第四方面提供了一种在分布式网络中用于处理事务的装置,所述装置包括:
处理器;以及
存储器,其用于存储指令,当所述指令执行时使得所述处理器执行以下操作:
事务接收方节点接收第一事务请求,其中,所述第一事务请求包括数字凭证标识信息;
在所述事务接收方节点的账本中获取与所述数字凭证标识信息相关联的第二数据;以及
将所述第二数据发送至所述第一事务请求的事务发起方节点,或者将所述第二数据发送至第一事务接收方节点,其中,所述第一事务接收方节点为向所述事务接收方节点发送所述第一事务请求的节点。
再者,本发明的实施例的第五方面提供了一种在分布式网络中用于处理事务的方法,所述方法包括:
事务发起方节点,接收第二事务请求,其中,所述第二事务请求包括与所述第二事务请求相关联的至少一个事务接收方节点的地址信息;
基于地址信息,通过点对点方式将所述第二事务请求发送至所述至少一个事务接收方节点;以及
在所述事务发起方节点的本地账本上存储与所述第二事务请求相关联的数据。
另外,本发明的实施例的第六方面提供了一种在分布式网络中用于处理事务的装置,所述装置包括:
处理器;以及
存储器,其用于存储指令,当所述指令执行时使得所述处理器执行以下操作:
事务发起方节点,接收第二事务请求,其中,所述第二事务请求包括与所述第二事务请求相关联的至少一个事务接收方节点的地址信息;
基于地址信息,通过点对点方式将所述第二事务请求发送至所述至少一个事务接收方节点;以及
在所述事务发起方节点的本地账本上存储与所述第二事务请求相关联的数据。
再者,本发明的实施例还提供了一种计算机可读存储介质,其具有存储在其上的计算机可读程序指令,所述计算机可读程序指令用于执行根据本发明的前述实施例所述的在分布式网络中用于处理事务的方法。
通过依据本发明的实施例所提供的在分布式网络中用于处理事务的方法、在分布式网络中用于处理事务的装置以及相应的计算机可读存储介质通过仅仅在具体事务相关联的分布式节点的本地账本上存储与事务请求相关联的数据,从而能够减少甚至避免分布式网络的分布式节点的本地账本中与该分布式节点并不相关的数据;此外,通过所建立的事务请求在相关的分布式节点之间的转发机制能够获得不同的分布式节点上的与该事务请求相关联的响应。本发明的其他优势将在下文中进一步说明。
附图说明
结合附图并参考以下详细说明,本发明的各实施例的特征、优点及其他方面将变得更加明显,在此以示例性而非限制性的方式示出了本发明的若干实施例,在附图中:
图1示出了依据本发明的一个实施例所提出的在分布式账本上进行写操作和读操作时的分布式账本架构示意图100;
图2示出了依据本发明的一个实施例所提出的在分布式网络中用于处理事务的方法200的流程图;
图3示出了依据本发明的另一个实施例所提出的在分布式网络中用于处理事务的方法300的流程图;
图4示出了依据本发明的又一个实施例所提出的在分布式网络中用于处理事务的方法400的流程图;以及
图5示出了依据本发明的一个实施例所提出的在分布式网络中用于处理事务的装置500的示意图。
具体实施方式
以下参考附图详细描述本发明的各个示例性实施例。虽然以下所描述的示例性方法、装置包括在其它组件当中的硬件上执行的软件和/或固件,但是应当注意,这些示例仅仅是说明性的,而不应看作是限制性的。例如,考虑在硬件中独占地、在软件中独占地、或在硬件和软件的任何组合中可以实施任何或所有硬件、软件和固件组件。因此,虽然以下已经描述了示例性的方法和装置,但是本领域的技术人员应容易理解,所提供的示例并不用于限制用于实现这些方法和装置的方式。
此外,附图中的流程图和框图示出了根据本发明的各种实施例的方法和系统的可能实现的体系架构、功能和操作。应当注意,方框中所标注的功能也可以按照不同于附图中所标注的顺序发生。例如,两个接连地表示的方框实际上可以基本并行地执行,或者它们有时也可以按照相反的顺序执行,这取决于所涉及的功能。同样应当注意的是,流程图和/或框图中的每个方框、以及流程图和/或框图中的方框的组合,可以使用执行规定的功能或操作的专用的基于硬件的系统来实现,或者可以使用专用硬件与计算机指令的组合来实现。
本发明内容中的术语“第一”、“第二”等仅用于描述指代、目的或某具体事物,而不能理解为指示或暗示相对重要性,或者隐含指明所指示的技术特征的数量。
本发明内容中的术语“至少一个”是指一个或一个以上。
本发明内容中的术语“数字凭证”是指在区块链上呈现的、诸如应收账款凭证、股票凭证、股权凭证或收益权凭证等各种金融有价凭证。
本发明内容中的术语“数字凭证标识信息”是指能够在分布式账本中通过其唯一地匹配到数字凭证的信息,例如数字凭证的ID、流水号等。
本发明内容中的术语“第一数据”是指在事务发起方节点的本地账本中的数据,该数据与所述第一事务请求所期望查询的数字凭证具有关联关系。
本发明内容中的术语“第二数据”是指在事务接收方节点的本地账本中的数据,该数据与所述第一事务请求所期望查询的数字凭证具有关联关系。
本发明内容中的术语“事务发起方”是指一种客户端,该客户端可以通过分布式节点在分布式网络上发起事务。本发明内容中的术语“事务接收方”是指一种客户端,该客户端可以通过分布式节点在分布式网络上接收事务。
本发明内容中的术语“事务发起方节点”是指从客户端接收事务请求并且在分布式网络上发起事务的分布式节点;而本发明内容中的术语“事务接收方节点”是指接收由“事务发起方节点”发起的事务的分布式节点。
如上文所述,在现有的目前主流的分布式账本技术采用分布式存储模式,每个分布式节点保存相同备份,而且数据通过广播形式进行传播,从而使得每个分布式节点获得相同的账本信息。由于分布式网络中的事务并不一定都是与全部的分布式节点有关的,这就导致了有一部分分布式节点的本地账本中存储了与该分布式节点并不相关的数据,这些数据对于该分布式节点自身来说是没有价值的,但是这部分没有价值的数据还是占用了该分布式节点的本地账本空间。此外,由于当前的分布式网络中的事务均采取广播的形式进行事务请求的发送,这就导致了不相关的分布式节点也获得了该事务请求,这将会造成分布式账本技术中的数据存储存在数据隐私和安全两方面的问题。
为了解决以上所述的技术问题和潜在的其他技术问题,本发明的发明人创新性地想到改进现有的诸如区块链账本的分布式账本上的事务处理机制,在进行事务处理的写操作时不是采取广播的方式而是采取点对点通信的方式进行事务请求的发送,此外实现了仅在事务相关方节点上存储事务数据,而在非相关方节点上不存储事务数据,进而避免了不相关的数据存储。另一方面,在进行事务处理的读操作时,虽然单一的节点上并不存储有全部的事务数据,但是能够通过向相关方节点转发事务请求的方式获取全部的相关数据。
图1示出了依据本发明的一个实施例所提出的在分布式账本上进行写操作和读操作时的分布式账本架构示意图100。从图1中可以看出,该诸如区块链的分布式账本平台100包括但不限于通过网络连接起来的分布式节点(也可称为终端)101、102、103、104、105、106、107、108以及109,其中,分布式节点101、103、104通过无线网络与其他区块链终端连接,而分布式节点102、105、106、107、108以及109通过有线网络和其他分布式节点连接。
在依据本发明的一种应用场景中,事务发起方需要向事务接收方发起转账请求,具体来看例如客户端A需要向客户端B发起转账请求,其中,客户端A与分布式节点102相关联,而客户端B与分布式节点105相关联,此时,该转账请求中能够包括与该转账请求相关联的事务接收方节点(例如分布式节点105)的地址信息。分布式节点102在接收到该转账请求之后,便会分析该转账请求从而得到该转账请求的事务接收方节点的地址信息,得知该转账请求的事务接收方节点为例如分布式节点105之后,便会将该转账请求采取点对点的方式发送至事务接收方节点(例如分布式节点105)。换句话说,该在与客户端A相关联的分布式节点102和与客户端B相关联的分布式节点105之间的转账请求仅仅会在事务发起方节点102和事务接收方节点105之间传播,而不会采取广播的方式发送到各个分布式节点。从而使得与该转账请求相关联的数据仅仅保存在分布式节点102和分布式节点105的本地账本之上,而不会保存在其他分布式节点之上,由此确保了分布式账本中对于事务数据的目的性存储,而不会占用其他分布式节点的账本空间。再者,也提高了事务数据的隐私性和安全性。
在依据本发明的另一种应用场景中,如果有一个诸如债权的数字凭证先从与客户端A相关联的分布式节点102转给了与客户端B相关联的分布式节点105,而后再转给了与客户端C相关联的分布式节点108,即该诸如债权的数字凭证经过了两次转让。
当事务发起方希望查询该债权的转让记录的全部数据时,假如该事务发起方(即图中的客户端D)访问了分布式节点108,此时,分布式节点108起到事务发起方节点的作用,分布式节点108首先会查询自己的本地账本上的数据,以确定分布式节点108所拥有的与该债权相关联的第一数据,例如转让信息,然后,该分布式节点108还会基于该第一数据来确定除其自身之外还有没有其他与该债权相关联其他事务接收方节点。在存在与该债权相关联其他事务接收方节点的情况下,将会确定其他事务接收方节点的地址信息,在上述应用场景中,其事务接收方节点为分布式节点105,此时,分布式节点108将会把期望查询债权相关联的全部数据的事务请求转发给分布式节点105。
此时,分布式节点105起到事务接收方节点的作用,分布式节点105首先会查询自己的本地账本上的数据,以确定分布式节点105所拥有的与该债权相关联的第二数据,例如转让信息。此外,该分布式节点105还会基于该第二数据来确定除其自身之外还有没有其他与该债权相关联其他事务接收方节点。在存在与该债权相关联其他事务接收方节点的情况下,将会确定其他事务接收方节点的地址信息,在上述应用场景中,其事务接收方节点为分布式节点102,此时,分布式节点105将会把期望查询债权相关联的全部数据的事务请求转发给分布式节点102。
此时,分布式节点102起到事务接收方节点的作用,分布式节点102首先会查询自己的本地账本上的数据,以确定分布式节点102所拥有的与该债权相关联的另一个第二数据,例如转让信息。此外,该分布式节点102还会基于该另一个第二数据来确定除其自身、分布式节点105之外还有没有其他与该债权相关联其他事务接收方节点。在存在与该债权相关联其他事务接收方节点的情况下,将会确定其他事务接收方节点的地址信息,在上述应用场景中,不存在这样的事务接收方节点了,此时,分布式节点102不会再将期望查询债权相关联的全部数据的事务请求转发给任何其他的分布式节点了。
具体到第一数据和至少一个第二数据的数据传输来看,各个事务接收方节点既可以通过其前一个事务接收方节点进行转发,也能够将各自的第二数据直接发送给事务发起方节点,从而能够获得事务请求的响应,即在该应用场景下,即查询到了该债权的全部转让信息。
概括地讲,上面描述了期望查询债权相关联的全部数据的事务请求在各个分布式节点之间的转发流程。而各个分布式节点所拥有的具体的与该债权相关联的转让信息如何发送则存在多种技术方案,其中一种便是该事务请求中包含了事务发起方节点的相关信息,各个事务接收方节点将其所拥有的与该债权相关联的转让信息均发送给事务发起方节点,由事务发起方节点对以上数据进行综合,以获得最终期望查询的完整数据。另一种实现方式便是各个分布式节点将其所拥有的与该债权相关联的转让信息发送给向其发送事务请求的上一个分布式节点,最终转发至事务发起方节点。
除了上述的与该债权相关联的转让信息以及事务请求的介绍之外,依据本发明所提出的技术方案还能够包括鉴权过程,即例如能够根据白名单方式来实现对于对上述的事务请求的事务发起方进行的身份认证,以决定是否返回具体的与该债权相关联的转让信息以及是否转发相应的事务请求。例如,在进行对于上述的事务发起方进行身份认证时,能够根据事务发起方的身份验证信息以及上述的白名单来决定身份认证是否通过,如果通过可以继续上面上述的过程;但是如果没有通过,则不会进行上述的处理过程或者转发过程。
以下将结合图2、图3和图4来描述在读操作和写操作时,作为事务发起方节点或事务接收方节点的分布式节点各自的动作过程。
图2示出了依据本发明内容的一个实施例所提出的在分布式网络中用于处理事务的方法200的流程图。从图中可以看出,该在分布式网络中用于处理事务的方法200能够包括以下步骤:
首先,在方法步骤210中,事务发起方节点接收第一事务请求,其中,所述第一事务请求包括数字凭证标识信息,由此能够使得事务发起方节点获得该第一事务请求期望查询与哪个数字凭证有关的事务数据;
接下来,在方法步骤220中,在所述事务发起方节点的本地账本中获取与所述数字凭证标识信息相关联的第一数据,也就是说,事务发起方节点将会首先在自身的本地账本中查询所存在的与上面所确定的数字凭证相关联的第一数据;
然后,在方法步骤230中,基于所述第一数据获得所述第一事务请求的至少一个事务接收方节点的地址信息,即事务发起方节点会根据所查询得到的第一数据确定除了该事务发起方节点之外还有哪一个或者哪几个事务接收方节点与该第一事务请求有关,如果存在这样的事务接收方节点,那么最后,在方法步骤240中,将会基于所述地址信息向所述至少一个事务接收方节点转发所述第一事务请求。
在事务发起方节点向一个或者多个事务接收方节点发送了上述的第一事务请求之后,经过事务接收方节点的处理之后,事务发起方节点将会接收到源自其他事务接收方节点的响应,所以上述的在分布式网络中用于处理事务的方法200还能够包括以下步骤(图2中未示出),即从所述至少一个事务接收方节点处接收与所述数字凭证标识信息相关联的至少一个第二数据;基于所述第一数据和所述至少一个第二数据生成与所述第一事务请求相关联的响应;以及将所述响应返回至所述第一事务请求的事务发起方。由此使得事务发起方节点不存在完整的事务数据的情况下,事务发起方也能够通过上述的第一事务请求的转发机制来获得与期望查询的数字凭证相关联的全部数据。
在依据本发明的一些实施例中,上述方法还包括对所述第一事务请求的事务发起方进行身份认证,即例如上面提到的白名单方式对事务发起方进行身份验证,如果该事务发起方在白名单之中,那么该第一事务请求将会得到处理,即既会在事务发起方节点的本地账本上查询相应的第一数据,也会根据该第一数据将该第一事务请求转发给相关的事务接收方节点,并从相关的事务接收方节点处获取在其本地账本上所保存的与该数字凭证相关联的第二数据,然后基于上述的第一数据和第二数据获得该第一事务请求的响应,并将该响应返回给事务发起方。但是如果该事务发起方并不在上述的白名单之中,那么该第一事务请求将会被拒绝,也就不会有下面的本地账本查询以及第一事务请求的转发了。
在依据本发明的一些实施例中,所述第一数据包含数字凭证标识信息。通过这样的方式便能够确定在事务发起方节点的本地账本中如何获取到该第一数据。在依据本发明的一些实施例中,所述第一事务请求用于查询所述分布式网络中的数据。在依据本发明的一些实施例中,所述分布式网络为区块链网络。
图3示出了依据本发明内容的又一个实施例所提出的在分布式网络中用于处理事务的方法300的流程图。从图中可以看出,该在分布式网络中用于处理事务的方法300能够包括以下步骤:
首先,在方法步骤310中,事务接收方节点接收第一事务请求,其中,所述第一事务请求包括数字凭证标识信息;
接下来,在方法步骤320中,在所述事务接收方节点的账本中获取与所述数字凭证标识信息相关联的第二数据;以及
最后,在方法步骤330中,将所述第二数据发送至所述第一事务请求的事务发起方节点,或者将所述第二数据发送至第一事务接收方节点,其中,所述第一事务接收方节点为向所述事务接收方节点发送所述第一事务请求的节点。
以这样的方式,事务接收方节点不仅能够获取其自身的本地账本中第二数据,其中,该第二数据与期望查询的数字凭证有关。
此外,图3中示出的在分布式网络中用于处理事务的方法300还能够包括以下步骤(图3中未示出),即:
根据所述第二数据,确定是否存在与所述第一事务请求相关联的第二事务接收方节点,所述第二事务接收方节点与所述事务发起方节点、所述事务接收方节点以及所述第一事务接收方节点均不相同;
在存在所述第二事务接收方节点的情况下,基于所述第二数据获得所述第二事务接收方节点的地址信息;以及
基于所述第二事务接收方节点的地址信息,向所述第二事务接收方节点转发所述第一事务请求。
以这样的方式能够根据所查询的到的第二数据来判断是否存在第二事务接收方节点,并且在存在第二事务接收方节点的情况下将第一事务请求转发给该第二事务接收方节点。
在依据本发明的一些实施例中,事务接收方节点接收第一事务请求进一步包括:事务接收方节点从所述第一事务请求的事务发起方节点接收所述第一事务请求,或者所述事务接收方节点从第一事务接收方节点接收所述第一事务请求。以这样的方式能够明确:上述的事务接收方节点并不一定是直接从事务发起方节点接收该第一事务请求的事务接收方节点,其也可能时接收到其他事务接收方节点所转发的第一事务请求的事务接收方节点。
在依据本发明的一些实施例中,对所述第一事务请求的事务发起方进行身份认证,即例如上面提到的白名单方式对事务发起方进行身份验证,如果该事务发起方在白名单之中,那么该第一事务请求将会得到处理,即既会在事务接收方节点的本地账本上查询相应的第二数据,也会根据该第二数据将该第一事务请求转发给相关的事务接收方节点,并从相关的事务接收方节点处获取在其本地账本上所保存的与该数字凭证相关联的其他第二数据,然后综合来获得该第一事务请求的响应,并将该响应返回给事务发起方。但是如果该事务发起方并不在上述的白名单之中,那么该第一事务请求将会被拒绝,也就不会有下面的本地账本查询以及第一事务请求的转发了。
图4示出了依据本发明内容的另一个实施例所提出的在分布式网络中用于处理事务的方法400的流程图。从图中可以看出,该在分布式网络中用于处理事务的方法400能够包括以下步骤:
首先,在方法步骤410中,事务发起方节点,接收第二事务请求,其中,所述第二事务请求包括与所述第二事务请求相关联的至少一个事务接收方节点的地址信息;
接下来,在方法步骤420中,基于地址信息,通过点对点方式将所述第二事务请求发送至所述至少一个事务接收方节点;以及
最后,在方法步骤430中,在所述事务发起方节点的本地账本上存储与所述第二事务请求相关联的数据。
以这样的方式,能够通过点对点方式将所述第二事务请求发送至所述至少一个事务接收方节点,而不是通过广播方式进行发送,从而减少了分布式节点的本地账本中与自身分布式节点不相关的数据量。
在依据本发明的一些实施例中,所述方法还包括:指示所述至少一个事务接收方节点在其账本上存储与所述第二事务请求相关联的数据。以这样的方式使得接收方节点在其账本上存储与第二事务请求所发起的事务的数据。
上述的与所述第二事务请求相关联的数据是为了记录事务发起方所发起的事务的数据,例如在进行转账操作时,与所述第二事务请求相关联的数据便是与转账请求相关联的数据,通过上述的方式,与转账请求相关联的数据仅仅保存在事务发起方节点和事务接收方节点的本地账本之上,而不会保存在其他分布式节点之上,由此确保了分布式账本中对于事务数据的目的性存储,而不会占用其他分布式节点的账本空间。
在依据本发明的一些实施例中,该方法400还能够包括对所述第二事务请求的事务发起方进行身份认证。如前所述,通过对事务发起方进行身份验证能够对事务发起方进行权限控制,从而降低非授权用户对于分布式节点上的账本的误操作的可能性。
在依据本发明的一些实施例中,所述第二事务请求用于基于所发起的事务向所述分布式网络的分布式账本中写入数据。以这样的方式能够通过仅仅在具体事务相关联的分布式节点的本地账本上存储与事务请求相关联的数据,从而能够减少甚至避免分布式网络的分布式节点的本地账本中与该分布式节点并不相关的数据。
此外,替代地,上述方法能够通过计算机程序产品,即计算机可读存储介质来实现。计算机程序产品可以包括计算机可读存储介质,其上载有用于执行本发明内容的各个方面的计算机可读程序指令。计算机可读存储介质可以是可以保持和存储由指令执行设备使用的指令的有形设备。计算机可读存储介质例如可以是但不限于电存储设备、磁存储设备、光存储设备、电磁存储设备、半导体存储设备或者上述的任意合适的组合。计算机可读存储介质的更具体的例子(非穷举的列表)包括:便携式计算机盘、硬盘、随机存取存储器(RAM)、只读存储器(ROM)、可擦式可编程只读存储器(EPROM或闪存)、静态随机存取存储器(SRAM)、便携式压缩盘只读存储器(CD-ROM)、数字多功能盘(DVD)、记忆棒、软盘、机械编码设备、例如其上存储有指令的打孔卡或凹槽内凸起结构、以及上述的任意合适的组合。这里所使用的计算机可读存储介质不被解释为瞬时信号本身,诸如无线电波或者其他自由传播的电磁波、通过波导或其他传输媒介传播的电磁波(例如,通过光纤电缆的光脉冲)、或者通过电线传输的电信号。
一般而言,本发明的各种示例实施例可以在硬件或专用电路、软件、固件、逻辑,或其任何组合中实施。某些方面可以在硬件中实施,而其他方面可以在可以由控制器、微处理器或其他计算设备执行的固件或软件中实施。当本发明的实施例的各方面被图示或描述为框图、流程图或使用某些其他图形表示时,将理解此处描述的方框、装置、系统、技术或方法可以作为非限制性的示例在硬件、软件、固件、专用电路或逻辑、通用硬件或控制器或其他计算设备,或其某些组合中实施。
图5示出了依据本发明内容的一个实施例所提出的用于搜索区块链数据的装置500的方框图。从图5中可以看出,用于搜索区块链数据的装置500包括处理器510和与处理器510耦接的存储器520。
存储器520存储有指令。指令在由处理器510执行时使得处理器510执行以下动作:
事务发起方节点接收第一事务请求,其中,所述第一事务请求包括数字凭证标识信息;
在所述事务发起方节点的本地账本中获取与所述数字凭证标识信息相关联的第一数据;
基于所述第一数据获得所述第一事务请求的至少一个事务接收方节点的地址信息;以及
基于所述地址信息向所述至少一个事务接收方节点转发所述第一事务请求。
在依据本发明的一个实施例中,当所述指令执行时还使得所述处理器510执行以下操作:
从所述至少一个事务接收方节点处接收与所述数字凭证标识信息相关联的至少一个第二数据;
基于所述第一数据和所述至少一个第二数据生成与所述第一事务请求相关联的响应;以及
将所述响应返回至所述第一事务请求的事务发起方。
在依据本发明的一个实施例中,当所述指令执行时使得所述处理器510执行以下操作:
对所述第一事务请求的事务发起方进行身份认证。
在依据本发明的一些实施例中,所述第一数据包含所述数字凭证标识信息。
在依据本发明的一个实施例中,所述第一事务请求用于查询所述分布式网络中的数据。在依据本发明的一个实施例中,所述分布式网络为区块链网络。
在依据本发明的一个实施例中,当所述指令执行时使得所述处理器510执行以下操作:
事务接收方节点接收第一事务请求,其中,所述第一事务请求包括数字凭证标识信息;
在所述事务接收方节点的账本中获取与所述数字凭证标识信息相关联的第二数据;以及
将所述第二数据发送至所述第一事务请求的事务发起方节点,或者将所述第二数据发送至第一事务接收方节点,其中,所述第一事务接收方节点为向所述事务接收方节点发送所述第一事务请求的节点。
在依据本发明的一个实施例中,当所述指令执行时还使得所述处理器510执行以下操作:
根据所述第二数据,确定是否存在与所述第一事务请求相关联的第二事务接收方节点,所述第二事务接收方节点与所述事务发起方节点、所述事务接收方节点以及所述第一事务接收方节点均不相同;
在存在所述第二事务接收方节点的情况下,基于所述第二数据获得所述第二事务接收方节点的地址信息;以及
基于所述第二事务接收方节点的地址信息,向所述第二事务接收方节点转发所述第一事务请求。
在依据本发明的一个实施例中,事务接收方节点接收第一事务请求进一步包括:事务接收方节点从所述第一事务请求的事务发起方节点接收所述第一事务请求,或者所述事务接收方节点从第一事务接收方节点接收所述第一事务请求。
在依据本发明的一个实施例中,当所述指令执行时还使得所述处理器510执行以下操作:
对所述第一事务请求的事务发起方进行身份认证。
在依据本发明的一个实施例中,当所述指令执行时使得所述处理器510执行以下操作:
事务发起方节点,接收第二事务请求,其中,所述第二事务请求包括与所述第二事务请求相关联的至少一个事务接收方节点的地址信息;
基于所述地址信息,通过点对点方式将所述第二事务请求发送至所述至少一个事务接收方节点;以及
在所述事务发起方节点的本地账本上存储与所述第二事务请求相关联的数据。
在依据本发明的一个实施例中,当所述指令执行时还使得所述处理器510执行以下操作:
对所述第二事务请求的事务发起方进行身份认证。
在依据本发明的一个实施例中,当所述指令执行时还使得所述处理器510执行以下操作:指示所述至少一个事务接收方节点在其账本上存储与所述第二事务请求相关联的数据。
虽然上面描述了本发明的各种示例实施例可以在硬件或专用电路中实现,但是上述用于区块链的数据处理设备既可以以硬件的形式来实现,也可以通过软件的形式来实现,这是因为:在20世纪90年代,一个技术改进能够很容易地对该改进属于硬件上的改进(例如,对二极管、晶体管、开关等电路结构的改进)还是属于软件上的改进(例如对于方法流程的改进)。然而,随着技术的持续发展,如今的很多方法流程的改进几乎都能够通过将改进的方法流程编程到硬件电路中来实现,换句话说,通过对于硬件电路编程不同的程序从而得到相应的硬件电路结构,即实现了硬件电路结构的改变,故这样的方法流程的改进也可以被视为硬件电路结构的直接改进。因此,不能说一个方法流程的改进就不能用硬件实体模块来实现。例如,可编程逻辑器件(Programmable Logic Device:PLD)(例如现场可编程门阵列(Field Programmable Gate Array:FPGA))就是这样一种集成电路,其逻辑功能由用户对器件编程来确定。由设计人员自行编程来把一个数字系统“集成”在一片可编程逻辑器件上,而不需要请芯片制造厂商来设计和制作专用的集成电路芯片。而且,如今取代手工地制作集成电路芯片,这种编程也多半改用“逻辑编译器(logic compi1er)”软件来实现,它与程序开发撰写时所用的软件编译器相类似,而要编译之前的原始代码也得用特定的编程语言来撰写,此称之为硬件描述语言(Hardware Description Language:HDL),而HDL也并非仅有—种,而是有许多种,如ABEL(Advanced Boolean Expression Language)、AHDL(Altera Hardware Description Language)、Confluence、CUPL(Cornell UniversityProgramming Language)、HDCal、JHDL(Java Hardware Description Language)、Lava、Lola、MyHDL、PALASM、RHDL(Ruby Hardware Description Language)等,目前最普遍使用的是VHDL(Very-High-Speed Integrated Circuit Hardware Description Language)与Verilog。本领域技术人员也应该清楚,只需要将方法流程用上述几种硬件描述语言稍作逻辑编程并编程到集成电路中,就可以很容易得到实现该逻辑方法流程的硬件电路。
用于执行本发明内容的各个方面的计算机可读程序指令或者计算机程序产品也能够存储在云端,在需要调用时,用户能够通过移动互联网、固网或者其他网络访问存储在云端上的用于执行本发明内容的一方面的计算机可读程序指令,从而实施依据本发明内容的各个方面所公开的技术方案。
以上所述仅为本发明内容的实施例可选实施例,并不用于限制本发明的实施例,对于本领域的技术人员来说,本发明的实施例可以有各种更改和变化。凡在本发明的实施例的精神和原则之内,所作的任何修改、等效替换、改进等,均应包含在本发明的实施例的保护范围之内。
虽然已经参考若干具体实施例描述了本发明的实施例,但是应当理解,本发明的实施例并不限于所公开的具体实施例。本发明的实施例旨在涵盖在所附权利要求的精神和范围内所包括的各种修改和等同布置。权利要求的范围符合最宽泛的解释,从而包含所有这样的修改及等同结构和功能。
Claims (27)
1.一种在分布式网络中处理事务的方法,所述方法包括:
事务发起方节点接收第一事务请求,其中,所述第一事务请求包括数字凭证标识信息;
在所述事务发起方节点的本地账本中获取与所述数字凭证标识信息相关联的第一数据;
基于所述第一数据获得所述第一事务请求的至少一个事务接收方节点的地址信息;以及
基于所述地址信息向所述至少一个事务接收方节点转发所述第一事务请求。
2.根据权利要求1所述的方法,所述方法还包括:
从所述至少一个事务接收方节点处接收与所述数字凭证标识信息相关联的至少一个第二数据;
基于所述第一数据和所述至少一个第二数据生成与所述第一事务请求相关联的响应;以及
将所述响应返回至所述第一事务请求的事务发起方。
3.根据权利要求1所述的方法,所述方法还包括:
对所述第一事务请求的事务发起方进行身份认证。
4.根据权利要求1所述的方法,其中,所述第一数据包含所述数字凭证标识信息。
5.根据权利要求1至4中任一项所述的方法,其中,所述第一事务请求用于查询所述分布式网络中的数据。
6.根据权利要求1所述的方法,其中,所述分布式网络为区块链网络。
7.一种在分布式网络中用于处理事务的装置,所述装置包括:
处理器;以及
存储器,其用于存储指令,当所述指令执行时使得所述处理器执行以下操作:
事务发起方节点接收第一事务请求,其中,所述第一事务请求包括数字凭证标识信息;
在所述事务发起方节点的本地账本中获取与所述数字凭证标识信息相关联的第一数据;
基于所述第一数据获得所述第一事务请求的至少一个事务接收方节点的地址信息;以及
基于所述地址信息向所述至少一个事务接收方节点转发所述第一事务请求。
8.根据权利要求7所述的装置,当所述指令执行时还使得所述处理器执行以下操作:
从所述至少一个事务接收方节点处接收与所述数字凭证标识信息相关联的至少一个第二数据;
基于所述第一数据和所述至少一个第二数据生成与所述第一事务请求相关联的响应;以及
将所述响应返回至所述第一事务请求的事务发起方。
9.根据权利要求7所述的装置,当所述指令执行时还使得所述处理器执行以下操作:
对所述第一事务请求的事务发起方进行身份认证。
10.根据权利要求7所述的装置,其中,所述第一数据包含所述数字凭证标识信息。
11.根据权利要求7至10中任一项所述的装置,其中,所述第一事务请求用于查询所述分布式网络中的数据。
12.根据权利要求7所述的装置,其中,所述分布式网络为区块链网络。
13.一种在分布式网络中用于处理事务的方法,所述方法包括:
事务接收方节点接收第一事务请求,其中,所述第一事务请求包括数字凭证标识信息;
在所述事务接收方节点的账本中获取与所述数字凭证标识信息相关联的第二数据;以及
将所述第二数据发送至所述第一事务请求的事务发起方节点,或者将所述第二数据发送至第一事务接收方节点,其中,所述第一事务接收方节点为向所述事务接收方节点发送所述第一事务请求的节点。
14.根据权利要求13所述的方法,其中,事务接收方节点接收第一事务请求进一步包括:事务接收方节点从所述第一事务请求的事务发起方节点接收所述第一事务请求,或者所述事务接收方节点从第一事务接收方节点接收所述第一事务请求。
15.根据权利要求14所述的方法,所述方法还包括:
根据所述第二数据,确定是否存在与所述第一事务请求相关联的第二事务接收方节点,所述第二事务接收方节点与所述事务发起方节点、所述事务接收方节点以及所述第一事务接收方节点均不相同;
在存在所述第二事务接收方节点的情况下,基于所述第二数据获得所述第二事务接收方节点的地址信息;以及
基于所述第二事务接收方节点的地址信息,向所述第二事务接收方节点转发所述第一事务请求。
16.根据权利要求13所述的方法,所述方法还包括:
对所述第一事务请求的事务发起方进行身份认证。
17.一种在分布式网络中用于处理事务的装置,所述装置包括:
处理器;以及
存储器,其用于存储指令,当所述指令执行时使得所述处理器执行以下操作:
事务接收方节点接收第一事务请求,其中,所述第一事务请求包括数字凭证标识信息;
在所述事务接收方节点的账本中获取与所述数字凭证标识信息相关联的第二数据;以及
将所述第二数据发送至所述第一事务请求的事务发起方节点,或者将所述第二数据发送至第一事务接收方节点,其中,所述第一事务接收方节点为向所述事务接收方节点发送所述第一事务请求的节点。
18.根据权利要求17所述的装置,其中,事务接收方节点接收第一事务请求进一步包括:事务接收方节点从所述第一事务请求的事务发起方节点接收所述第一事务请求,或者所述事务接收方节点从第一事务接收方节点接收所述第一事务请求。
19.根据权利要求17所述的装置,当所述指令执行时还使得所述处理器执行以下操作:
根据所述第二数据,确定是否存在与所述第一事务请求相关联的第二事务接收方节点,所述第二事务接收方节点与所述事务发起方节点、所述事务接收方节点以及所述第一事务接收方节点均不相同;
在存在所述第二事务接收方节点的情况下,基于所述第二数据获得所述第二事务接收方节点的地址信息;以及
基于所述第二事务接收方节点的地址信息,向所述第二事务接收方节点转发所述第一事务请求。
20.根据权利要求17所述的装置,当所述指令执行时还使得所述处理器执行以下操作:
对所述第一事务请求的事务发起方进行身份认证。
21.一种在分布式网络中用于处理事务的方法,所述方法包括:
事务发起方节点接收第二事务请求,其中,所述第二事务请求包括与所述第二事务请求相关联的至少一个事务接收方节点的地址信息;
基于所述地址信息,通过点对点方式将所述第二事务请求发送至所述至少一个事务接收方节点;以及
在所述事务发起方节点的本地账本上存储与所述第二事务请求相关联的数据。
22.根据权利要求21所述的方法,其中,所述方法还包括:指示所述至少一个事务接收方节点在其账本上存储与所述第二事务请求相关联的数据。
23.根据权利要求21所述的方法,所述方法还包括:
对所述第二事务请求的发起方进行身份认证。
24.一种在分布式网络中用于处理事务的装置,所述装置包括:
处理器;以及
存储器,其用于存储指令,当所述指令执行时使得所述处理器执行以下操作:
事务发起方节点,接收第二事务请求,其中,所述第二事务请求包括与所述第二事务请求相关联的至少一个事务接收方节点的地址信息;
基于所述地址信息,通过点对点方式将所述第二事务请求发送至所述至少一个事务接收方节点;以及
在所述事务发起方节点的本地账本上存储与所述第二事务请求相关联的数据。
25.根据权利要求24所述的装置,当所述指令执行时还使得所述处理器执行以下操作:指示所述至少一个事务接收方节点在其账本上存储与所述第二事务请求相关联的数据。
26.根据权利要求24所述的装置,当所述指令执行时还使得所述处理器执行以下操作:
对所述第二事务请求的事务发起方进行身份认证。
27.一种计算机可读存储介质,其具有存储在其上的计算机可读程序指令,所述计算机可读程序指令用于执行根据权利要求1-4、9-13以及19-22中任一项所述的在分布式网络中用于处理事务的方法。
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN201810875767.7A CN109118220A (zh) | 2018-08-03 | 2018-08-03 | 在分布式网络中用于处理事务的方法、装置及存储介质 |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN201810875767.7A CN109118220A (zh) | 2018-08-03 | 2018-08-03 | 在分布式网络中用于处理事务的方法、装置及存储介质 |
Publications (1)
Publication Number | Publication Date |
---|---|
CN109118220A true CN109118220A (zh) | 2019-01-01 |
Family
ID=64852986
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
CN201810875767.7A Pending CN109118220A (zh) | 2018-08-03 | 2018-08-03 | 在分布式网络中用于处理事务的方法、装置及存储介质 |
Country Status (1)
Country | Link |
---|---|
CN (1) | CN109118220A (zh) |
Cited By (2)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
WO2020237557A1 (zh) * | 2019-05-30 | 2020-12-03 | 比特大陆科技有限公司 | 中转数字凭证处理任务的方法和设备、介质和程序产品 |
CN113901144A (zh) * | 2021-10-15 | 2022-01-07 | 北京智融云河科技有限公司 | 非全网共识区块链下的查询方法、设备及存储介质 |
Citations (6)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN107124278A (zh) * | 2017-03-30 | 2017-09-01 | 腾讯科技(深圳)有限公司 | 业务处理方法、装置以及数据共享系统 |
CN107451275A (zh) * | 2017-08-04 | 2017-12-08 | 北京明朝万达科技股份有限公司 | 基于区块链的业务数据处理方法、装置、系统和存储设备 |
CN107622096A (zh) * | 2017-08-31 | 2018-01-23 | 上海保险交易所股份有限公司 | 基于区块链系统的异步多方数据交互方法和存储介质 |
CN107679369A (zh) * | 2016-08-02 | 2018-02-09 | 华为技术有限公司 | 一种共享数字内容的许可证的方法、装置及系统 |
CN107809484A (zh) * | 2017-10-30 | 2018-03-16 | 中国联合网络通信集团有限公司 | 区块链交易信息处理方法及区块链节点 |
WO2018120129A1 (zh) * | 2016-12-30 | 2018-07-05 | 深圳前海达闼云端智能科技有限公司 | 数据查询方法、装置及节点设备 |
-
2018
- 2018-08-03 CN CN201810875767.7A patent/CN109118220A/zh active Pending
Patent Citations (6)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN107679369A (zh) * | 2016-08-02 | 2018-02-09 | 华为技术有限公司 | 一种共享数字内容的许可证的方法、装置及系统 |
WO2018120129A1 (zh) * | 2016-12-30 | 2018-07-05 | 深圳前海达闼云端智能科技有限公司 | 数据查询方法、装置及节点设备 |
CN107124278A (zh) * | 2017-03-30 | 2017-09-01 | 腾讯科技(深圳)有限公司 | 业务处理方法、装置以及数据共享系统 |
CN107451275A (zh) * | 2017-08-04 | 2017-12-08 | 北京明朝万达科技股份有限公司 | 基于区块链的业务数据处理方法、装置、系统和存储设备 |
CN107622096A (zh) * | 2017-08-31 | 2018-01-23 | 上海保险交易所股份有限公司 | 基于区块链系统的异步多方数据交互方法和存储介质 |
CN107809484A (zh) * | 2017-10-30 | 2018-03-16 | 中国联合网络通信集团有限公司 | 区块链交易信息处理方法及区块链节点 |
Cited By (3)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
WO2020237557A1 (zh) * | 2019-05-30 | 2020-12-03 | 比特大陆科技有限公司 | 中转数字凭证处理任务的方法和设备、介质和程序产品 |
CN113901144A (zh) * | 2021-10-15 | 2022-01-07 | 北京智融云河科技有限公司 | 非全网共识区块链下的查询方法、设备及存储介质 |
CN113901144B (zh) * | 2021-10-15 | 2024-02-06 | 北京智融云河科技有限公司 | 非全网共识区块链下的查询方法、设备及存储介质 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
Majeed et al. | Blockchain for IoT-based smart cities: Recent advances, requirements, and future challenges | |
O'Leary | Configuring blockchain architectures for transaction information in blockchain consortiums: The case of accounting and supply chain systems | |
US20190325473A1 (en) | Reward point redemption for cryptocurrency | |
CN110417558A (zh) | 签名的验证方法和装置、存储介质及电子装置 | |
WO2020028589A1 (en) | Techniques for expediting processing of blockchain transactions | |
CN109492419A (zh) | 用于获取区块链中的数据的方法、装置及存储介质 | |
US20190019186A1 (en) | Systems and methods for automated decentralized multilateral transaction processing | |
CN110024357A (zh) | 使用分布式分类帐进行数据处理的系统和方法 | |
CN109522362A (zh) | 基于区块链数据的非完全数据同步方法、系统及设备 | |
CN110163004A (zh) | 一种区块链生成的方法、相关设备及系统 | |
CN109669943A (zh) | 数据存储方法、数据查询方法及装置 | |
CN110430186A (zh) | 基于代理重加密和智能合约的区块链数据交易系统及方法 | |
US20230006845A1 (en) | Systems and methods for blockchain storage of data generated via paired smartphone and smartwatch | |
CN111066043B (zh) | 实现银行间信息网络的系统和方法 | |
CN105635168B (zh) | 一种脱机交易装置及其安全密钥的使用方法 | |
US20150256603A1 (en) | System and method for aggregating and providing data from enterprise systems to mobile devices | |
Yadav | Blockchain Security | |
US11270004B2 (en) | Blockchain-based transaction privacy | |
CN113409045A (zh) | 一种基于区块链的数据处理方法、装置及电子设备 | |
CN109547200A (zh) | 区块链网络中的证书分配方法及相应的计算设备和介质 | |
CN109359963A (zh) | 医保结算方法及装置和电子设备 | |
CN110503435A (zh) | 基于区块链的交易预警方法、装置及设备 | |
CN108074024A (zh) | 风险识别方法、装置及系统 | |
CN110198265A (zh) | 信息处理方法、系统、装置、设备和介质 | |
CN109118220A (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 | ||
RJ01 | Rejection of invention patent application after publication |
Application publication date: 20190101 |
|
RJ01 | Rejection of invention patent application after publication |