一种区块链网络链外数据上链方法和装置
技术领域
本发明涉及通信领域,尤其涉及一种区块链网络链外数据上链方法和装置。
背景技术
随着区块链技术的大规模应用,区块链网络作为数据孤岛的弊端越来越明显。区块链网络上分散式应用程序DAPP(Decentralized Application)对于现实世界公认数据的需求越来越强烈。
区块链网络中会需要很多链外公认数据,公认数据,可以是公众认可的没有争议的数据,这些数据往往是客观的,比如,知名交易所(数字货币交易所、证券交易所、商品交易所)在某个时间的指数、某项著名体育赛事的结果或者美国大选的结果等等。那么就会遇到一个问题:如何采集这个数据,区块链如何对这个数据达成共识。
现有的解决方案通常是用类似中心化服务器的中介节点介入,同时需要部署第三方的智能合约,来实现链外数据上链和不同链间数据同步。然而,通过第三方智能合约往往需要中心化服务器介入,中心化服务器会存在鲁棒性、安全性等问题。
发明内容
本发明实施例提供一种区块链网络链外数据上链方法、装置、存储介质和电子设备,以解决现有的外链数据上链存在中心化的问题。
为了解决上述技术问题,本发明是这样实现的:
第一方面,提供了一种区块链网络链外数据上链方法,该方法包括:
预言机oracle发布待上链公认数据的描述信息;
第一共识节点根据所述描述信息,采集链外的数据;
第一共识节点将采集的数据传递给投票vote智能合约,以对待上链公认数据进行投票;
在vote智能合约确定收到的数据中目标数据的票数满足预设条件时,则确定所述目标数据为待上链公认数据。
第二方面,提供了一种区块链网络链外数据上链装置,该装置包括:
发布模块,发布待上链公认数据的描述信息;
采集模块,根据所述描述信息,采集链外的数据;
投票模块,将采集的数据传递给投票vote智能合约,以对待上链公认数据进行投票;
确定模块,在vote智能合约确定收到的数据中目标数据的票数满足预设条件时,则确定所述目标数据为待上链公认数据。
第三方面,提供了一种电子设备,该电子设备包括:
处理器;以及
被安排成存储计算机可执行指令的存储器,所述可执行指令在被执行时使所述处理器执行以下操作:
预言机oracle发布待上链公认数据的描述信息;
第一共识节点根据所述描述信息,采集链外的数据;
第一共识节点将采集的数据传递给投票vote智能合约,以对待上链公认数据进行投票;
在vote智能合约确定收到的数据中目标数据的票数满足预设条件时,则确定所述目标数据为待上链公认数据。
第四方面,提供了一种计算机可读存储介质,所述计算机可读存储介质存储一个或多个程序,所述一个或多个程序当被包括多个应用程序的电子设备执行时,使得所述电子设备执行以下操作:
预言机oracle发布待上链公认数据的描述信息;
第一共识节点根据所述描述信息,采集链外的数据;
第一共识节点将采集的数据传递给投票vote智能合约,以对待上链公认数据进行投票;
在vote智能合约确定收到的数据中目标数据的票数满足预设条件时,则确定所述目标数据为待上链公认数据。
在本发明实施例中,在对区块链外的公认数据进行上链时,先由预言机oracle发布待上链公认数据的描述信息,然后共识节点根据该描述信息,去采集链外的数据,并将采集的数据传递给投票vote智能合约,以对待上链公认数据进行投票,在vote智能合约确定收到的数据中目标数据的票数满足预设条件时,则确定所述目标数据为待上链公认数据。通过该方法,区块链中的共识节点,可以根据描述信息,自主地去采集链外的数据,通过投票的方式,来选取票数较多的数据,作为待上链的公认数据,即达成了对公认数据的共识。
附图说明
此处所说明的附图用来提供对本发明的进一步理解,构成本发明的一部分,本发明的示意性实施例及其说明用于解释本发明,并不构成对本发明的不当限定。在附图中:
图1是本发明实施例提供的一种区块链网络链外数据上链方法的流程示意图;
图2是本发明实施例提供的一种区块链网络链外数据上链装置的结构示意图;
图3为本发明实施例提供的电子设备的一种结构示意图。
具体实施方式
下面将结合本发明实施例中的附图,对本发明实施例中的技术方案进行清楚、完整地描述,显然,所描述的实施例是本发明一部分实施例,而不是全部的实施例。基于本发明中的实施例,本领域普通技术人员在没有作出创造性劳动前提下所获得的所有其他实施例,都属于本发明保护的范围。
如背景技术所描述的,现有技术,在通过类似中心化服务器的中介节点介入来实现链外数据上链时,同时还需要部署第三方的智能合约,来实现链外数据上链和不同链间数据同步。类似方法不仅仅存在中心化的问题,还存在2点不足:
第一,第三方的智能合约往往针对某种链外数据实现数据上链,可扩展性差。
第二,第三方智能合约能够调动的节点很少,并且抵押有限,从而影响了数据的准确性和安全性。缺少足够的公信力。
下面将对本提案进行详细描述。
为便于描述,本说明书一个或多个实施例中,区块链网络链外数据上链的执行主体可以是区块链网络中的共识节点,智能合约也可以是存在于共识节点之中的可执行代码程序。后文以执行主体为区块链网络中的共识节点为例,对该方法的实施方式进行介绍。可以理解,该方法的执行主体为区块链网络中的共识节点只是一种示例性的说明,并不应理解为对该方法的限定。
在本说明书一个或多个实施例中,区块链网络链外数据上链方法的实现流程示意图如图1所示,包括下述步骤:
步骤100:预言机oracle发布待上链公认数据的描述信息;
oracle合约可以通过发布待上链公认数据的描述信息,来发起一个公认数据上链项目。
待上链的公认数据,为需要上链的公认数据。而描述信息为用来对该公认数据进行描述的信息,例如,“2018年足球世界杯的冠军”为对公认数据“法国”的描述信息。
在本申请实施例中,描述信息用来对公认数据的客观事实进行描述,用来描述公认数据所具备的特征,或者是公认数据的限制性条件,一般是类似问题的形式,而具体的公认数据则为该问题的答案。
在本申请的一个或多个实施例中,公认数据的数据类型可以包括下述至少一种:
数字型;字符串型。
例如:描述信息“xx日的纳斯达克指数”的公认数据为“1234.5”,描述信息“2018年足球世界杯的冠军”的公认数据为“FRANCE”。
在本申请的一个或多个实施例中,待上链数据的数据类型不是布尔型bool。以避免不同的节点对同一数据采用不同的布尔取值描述时,将无法布尔值所表述的公认数据,无法实现对公认数据的共识。
步骤102,第一共识节点根据所述描述信息,采集链外的数据。
在本申请实施例中,只是公布公认数据的描述信息,而不指定具体的数据采集地址,以及具体的数据采集方式。共识节点可以采用任何方式去采集符和该描述信息的数据,以避免各共识节点所采集的数据来自同一地址,导致数据完全相同,便失去了后去共识的意义。由于本提案中所采集的是公认数据,因此,不管共识节点通过何种方式进行采集,最终所得到的数据应当是相同的,即使有错误,也应当仅仅会是少部分节点采集错误。
步骤104,第一共识节点将采集的数据传递给投票vote智能合约,以对待上链公认数据进行投票;
在区块链中,可以提供vote合约,来允许区块链委员会成员对公认数据上链项目中的待上链公认数据进行投票,委员会成员可以是区块链中所有有权利参与共识的节点,比如第一共识节点,即第一共识节点可以是区块链委员会成员,具备投票权。
共识节点将采集的数据传递给投票vote智能合约,来针对某一个具体公认数据上链项目中的待上链公认数据进行投票,具体可以通过push action的方式,将数据推送给vote智能合约,实现了对公认数据进行投票。
在对公认数据上链项目中的待上链公认数据进行投票时,由于具体的项目是确定的,因此具体传递的数据,可以只是公认数据的结果数据,比如,“FRANCE”,而无需再将“2018年足球世界杯的冠军”进行推送。
步骤104,在vote智能合约确定收到的数据中目标数据的票数满足预设条件时,则确定所述目标数据为待上链公认数据。
vote智能合约会收到区块链委员会成员(共识节点)所传递的数据,并对各个数据的票数(数量)进行统计,在某个项目中,目标数据的票数满足预设条件时,则确定该目标数据为待上链公认数据。这样该项目中的公认数据即得到了确定。比如,在项目“2018年足球世界杯的冠军”中,在确定了目标数据为“FRANCE”后,则可以在区块链中达成共识,确定“2018年足球世界杯的冠军为FRANCE”。
在本申请的一个或多个实施例中,预设条件可以是,某个数据的票数大于总票数的2/3,当然,为了防止小概率事件,总票数的数量也可以高于某个设定的阈值。这样,当区块链中,作恶节点占少数时,本发明方法可以通过分布式的方法,对公认数据达成共识,有效地、安全地完成对链外数据的上链。
在本申请的一个或多个实施例中,在确定目标数据为待上链公认数据后,还可以对投票数据与目标数据相同的节点给予奖励,比如给予一定的虚拟货币。如果投票数据与目标数据相同,则认为该节点投了正确的一票,那么可以对其正确行为予以鼓励。
或者,也可以对投票数据与目标数据不相同的节点进行惩罚,比如扣除其质押的虚拟货币。投票数据与目标数据不相同,则认为该节点投了错误的一票,那么可以对其错误行为予以惩罚。
另外,确定所述目标数据为待上链公认数据后,所述方法还包括:
在oracle合约中公布某个项目的待上链数据为所述目标数据,然后将该目标数据添加到区块链中。在将目标数据添加到区块链中时,可以将整个公认数据待上链项目中的所有信息都添加至区块链中。例如,将数据“2018年足球世界杯的冠军为FRANCE”添加至区块链中。
在本发明实施例中,在对区块链外的公认数据进行上链时,先由预言机oracle发布待上链公认数据的描述信息,然后共识节点根据该描述信息,去采集链外的数据,并将采集的数据传递给投票vote智能合约,以对待上链公认数据进行投票,在vote智能合约确定收到的数据中目标数据的票数满足预设条件时,则确定所述目标数据为待上链公认数据。通过该方法,区块链中的共识节点,可以根据描述信息,自主地去采集链外的数据,通过投票的方式,来选取票数较多的数据,作为待上链的公认数据,即达成了对公认数据的共识。
另外,本提案中可对任何链外数据进行上链,可扩展性强。并且,通过共识节点投票来对公认数据进行共识,能够调动共识节点,公信力更强,提高了数据的准确性和安全性。
以上为本申请实施例提供的区块链网络链外数据上链方法,基于同样的思路,本申请实施例还提供相应的区块链网络链外数据上链装置,如图2所示,该装置具体包括:
发布模块201,发布待上链公认数据的描述信息;
采集模块202,根据所述描述信息,采集链外的数据;
投票模块203,将采集的数据传递给投票vote智能合约,以对待上链公认数据进行投票;
确定模块204,在vote智能合约确定收到的数据中目标数据的票数满足预设条件时,则确定所述目标数据为待上链公认数据。
在一种实施方式中,所述待上链数据的数据类型不是bool型。
在一种实施方式中,所述装置还包括奖励模块205和/或惩罚模块206:
所述奖励模块205,在确定所述目标数据为待上链公认数据后,对投票数据与目标数据相同的节点给予奖励;
所述惩罚模块206,在确定所述目标数据为待上链公认数据后,对投票数据与目标数据不相同的节点进行惩罚。
在一种实施方式中,所述预设条件为,数据的票数大于总票数的2/3。
在一种实施方式中,所述装置还包括:
数据存储模块207,在确定所述目标数据为待上链公认数据后,在oracle合约中公布待上链数据为所述目标数据;
将所述目标数据添加到区块链中。
本发明提供的区块链网络链外数据上链装置,在对区块链外的公认数据进行上链时,先由预言机oracle发布待上链公认数据的描述信息,然后共识节点根据该描述信息,去采集链外的数据,并将采集的数据传递给投票vote智能合约,以对待上链公认数据进行投票,在vote智能合约确定收到的数据中目标数据的票数满足预设条件时,则确定所述目标数据为待上链公认数据。通过该方法,区块链中的共识节点,可以根据描述信息,自主地去采集链外的数据,通过投票的方式,来选取票数较多的数据,作为待上链的公认数据,即达成了对公认数据的共识。
图3是本申请的一个实施例电子设备的结构示意图。请参考图3,在硬件层面,该电子设备包括处理器,可选地还包括内部总线、网络接口、存储器。其中,存储器可能包含内存,例如高速随机存取存储器(Random-Access Memory,RAM),也可能还包括非易失性存储器(non-volatile memory),例如至少1个磁盘存储器等。当然,该电子设备还可能包括其他业务所需要的硬件。
处理器、网络接口和存储器可以通过内部总线相互连接,该内部总线可以是ISA(Industry Standard Architecture,工业标准体系结构)总线、PCI(PeripheralComponent Interconnect,外设部件互连标准)总线或EISA(Extended Industry StandardArchitecture,扩展工业标准结构)总线等。所述总线可以分为地址总线、数据总线、控制总线等。为便于表示,图3中仅用一个双向箭头表示,但并不表示仅有一根总线或一种类型的总线。
存储器,用于存放程序。具体地,程序可以包括程序代码,所述程序代码包括计算机操作指令。存储器可以包括内存和非易失性存储器,并向处理器提供指令和数据。
处理器从非易失性存储器中读取对应的计算机程序到内存中然后运行,在逻辑层面上形成区块链网络链外数据上链装置。处理器,执行存储器所存放的程序,并具体用于执行以下操作:
预言机oracle发布待上链公认数据的描述信息;
第一共识节点根据所述描述信息,采集链外的数据;
第一共识节点将采集的数据传递给投票vote智能合约,以对待上链公认数据进行投票;
在vote智能合约确定收到的数据中目标数据的票数满足预设条件时,则确定所述目标数据为待上链公认数据。
上述如本申请图1所示实施例揭示的区块链网络链外数据上链装置执行的方法可以应用于处理器中,或者由处理器实现。处理器可能是一种集成电路芯片,具有信号的处理能力。在实现过程中,上述方法的各步骤可以通过处理器中的硬件的集成逻辑电路或者软件形式的指令完成。上述的处理器可以是通用处理器,包括中央处理器(CentralProcessing Unit,CPU)、网络处理器(Network Processor,NP)等;还可以是数字信号处理器(Digital Signal Processor,DSP)、专用集成电路(Application Specific IntegratedCircuit,ASIC)、现场可编程门阵列(Field-Programmable Gate Array,FPGA)或者其他可编程逻辑器件、分立门或者晶体管逻辑器件、分立硬件组件。可以实现或者执行本申请实施例中的公开的各方法、步骤及逻辑框图。通用处理器可以是微处理器或者该处理器也可以是任何常规的处理器等。结合本申请实施例所公开的方法的步骤可以直接体现为硬件译码处理器执行完成,或者用译码处理器中的硬件及软件模块组合执行完成。软件模块可以位于随机存储器,闪存、只读存储器,可编程只读存储器或者电可擦写可编程存储器、寄存器等本领域成熟的存储介质中。该存储介质位于存储器,处理器读取存储器中的信息,结合其硬件完成上述方法的步骤。
该电子设备还可执行图1中区块链网络链外数据上链装置执行的方法,并实现区块链网络链外数据上链装置在图1所示实施例的功能,本申请实施例在此不再赘述。
本申请实施例还提出了一种计算机可读存储介质,该计算机可读存储介质存储一个或多个程序,该一个或多个程序包括指令,该指令当被包括多个应用程序的电子设备执行时,能够使该电子设备执行图1所示实施例中区块链网络链外数据上链装置执行的方法,并具体用于执行:
预言机oracle发布待上链公认数据的描述信息;
第一共识节点根据所述描述信息,采集链外的数据;
第一共识节点将采集的数据传递给投票vote智能合约,以对待上链公认数据进行投票;
在vote智能合约确定收到的数据中目标数据的票数满足预设条件时,则确定所述目标数据为待上链公认数据。
本申请实施例提供的电子设备和计算机可读存储介质,在对区块链外的公认数据进行上链时,先由预言机oracle发布待上链公认数据的描述信息,然后共识节点根据该描述信息,去采集链外的数据,并将采集的数据传递给投票vote智能合约,以对待上链公认数据进行投票,在vote智能合约确定收到的数据中目标数据的票数满足预设条件时,则确定所述目标数据为待上链公认数据。通过该方法,区块链中的共识节点,可以根据描述信息,自主地去采集链外的数据,通过投票的方式,来选取票数较多的数据,作为待上链的公认数据,即达成了对公认数据的共识。
本领域内的技术人员应明白,本发明的实施例可提供为方法、系统或计算机程序产品。因此,本发明可采用完全硬件实施例、完全软件实施例、或结合软件和硬件方面的实施例的形式。而且,本发明可采用在一个或多个其中包含有计算机可用程序代码的计算机可用存储介质(包括但不限于磁盘存储器、CD-ROM、光学存储器等)上实施的计算机程序产品的形式。
本发明是参照根据本发明实施例的方法、设备(系统)、和计算机程序产品的流程图和/或方框图来描述的。应理解可由计算机程序指令实现流程图和/或方框图中的每一流程和/或方框、以及流程图和/或方框图中的流程和/或方框的结合。可提供这些计算机程序指令到通用计算机、专用计算机、嵌入式处理机或其他可编程数据处理设备的处理器以产生一个机器,使得通过计算机或其他可编程数据处理设备的处理器执行的指令产生用于实现在流程图一个流程或多个流程和/或方框图一个方框或多个方框中指定的功能的装置。
这些计算机程序指令也可存储在能引导计算机或其他可编程数据处理设备以特定方式工作的计算机可读存储器中,使得存储在该计算机可读存储器中的指令产生包括指令装置的制造品,该指令装置实现在流程图一个流程或多个流程和/或方框图一个方框或多个方框中指定的功能。
这些计算机程序指令也可装载到计算机或其他可编程数据处理设备上,使得在计算机或其他可编程设备上执行一系列操作步骤以产生计算机实现的处理,从而在计算机或其他可编程设备上执行的指令提供用于实现在流程图一个流程或多个流程和/或方框图一个方框或多个方框中指定的功能的步骤。
在一个典型的配置中,计算设备包括一个或多个处理器(CPU)、输入/输出接口、网络接口和内存。
内存可能包括计算机可读介质中的非永久性存储器,随机存取存储器(RAM)和/或非易失性内存等形式,如只读存储器(ROM)或闪存(flash RAM)。内存是计算机可读介质的示例。
计算机可读介质包括永久性和非永久性、可移动和非可移动媒体可以由任何方法或技术来实现信息存储。信息可以是计算机可读指令、数据结构、程序的模块或其他数据。计算机的存储介质的例子包括,但不限于相变内存(PRAM)、静态随机存取存储器(SRAM)、动态随机存取存储器(DRAM)、其他类型的随机存取存储器(RAM)、只读存储器(ROM)、电可擦除可编程只读存储器(EEPROM)、快闪记忆体或其他内存技术、只读光盘只读存储器(CD-ROM)、数字多功能光盘(DVD)或其他光学存储、磁盒式磁带,磁带磁磁盘存储或其他磁性存储设备或任何其他非传输介质,可用于存储可以被计算设备访问的信息。按照本文中的界定,计算机可读介质不包括暂存电脑可读媒体(transitory media),如调制的数据信号和载波。
还需要说明的是,术语“包括”、“包含”或者其任何其他变体意在涵盖非排他性的包含,从而使得包括一系列要素的过程、方法、商品或者设备不仅包括那些要素,而且还包括没有明确列出的其他要素,或者是还包括为这种过程、方法、商品或者设备所固有的要素。在没有更多限制的情况下,由语句“包括一个……”限定的要素,并不排除在包括所述要素的过程、方法、商品或者设备中还存在另外的相同要素。
以上所述仅为本申请的实施例而已,并不用于限制本申请。对于本领域技术人员来说,本申请可以有各种更改和变化。凡在本申请的精神和原理之内所作的任何修改、等同替换、改进等,均应包含在本申请的权利要求范围之内。