区块验证方法及装置与流程

文档序号:13011544阅读:329来源:国知局
区块验证方法及装置与流程

本发明实施例涉及通信技术领域,尤其涉及一种区块验证方法及装置。



背景技术:

区块链是一串使用密码学方法相关联产生的数据块,每一个数据块中包含了一次比特币网络交易的信息,用于验证其信息的有效性(防伪)和生成下一个区块。

区块链本身具有自身的验证能力,但是前提是必须具有完整的区块链账本才能进行。区块链本身要求每个完整节点实时更新完整的区块链账本,这样任何节点都可以对任何一个区块进行验证。

但是,用户终端例如手机等往往不具备作为完整区块链节点的能力,当其他节点发送给用户终端一个区块的时候,用户终端无法验证该区块的真伪。



技术实现要素:

本发明实施例提供一种区块验证方法及装置,以实现对该区块的验证。

本发明实施例的一个方面是提供一种区块验证方法,包括:

接收根节点发送的区块的标识信息、哈希值和签名信息,所述签名信息是采用所述根节点的私钥对所述区块的标识信息、哈希值进行签名后得到的;

根据所述根节点的公钥对所述签名信息进行验证,若验证成功,则存储所述区块的标识信息、哈希值和签名信息的对应关系;

从服务器节点获取所需查询的区块,并计算所述区块的哈希值;

比较计算出的所述区块的哈希值和所述区块中携带的哈希值是否一致;

若一致,则通过比较所述区块中携带的哈希值和本地存储的所述区块的哈希值是否一致,对所述区块进行验证。

本发明实施例的另一个方面是提供一种区块验证装置,包括:

接收模块,用于接收根节点发送的区块的标识信息、哈希值和签名信息,所述签名信息是采用所述根节点的私钥对所述区块的标识信息、哈希值进行签名后得到的;

验证模块,用于根据所述根节点的公钥对所述签名信息进行验证;

存储模块,用于当所述验证模块根据所述根节点的公钥对所述签名信息验证成功时,存储所述区块的标识信息、哈希值和签名信息的对应关系;

获取模块,用于从服务器节点获取所需查询的区块;

计算模块,用于计算所述区块的哈希值;

比较模块,用于比较计算出的所述区块的哈希值和所述区块中携带的哈希值是否一致;若一致,则比较所述区块中携带的哈希值和本地存储的所述区块的哈希值是否一致;

所述验证模块根据所述比较模块的比较结果对所述区块进行验证。

本发明实施例提供的区块验证方法及装置,通过移动终端节点接收根节点发送的区块的标识信息、哈希值和签名信息,并存储所述区块的标识信息、哈希值和签名信息的对应关系,当移动终端节点从服务器节点获取到所需查询的区块之后,通过比较该区块中携带的哈希值和本地存储的该区块的哈希值是否一致,以实现对该区块的验证。

附图说明

图1为本发明实施例提供的区块验证方法流程图;

图2为本发明另一实施例提供的区块验证方法流程图;

图3为本发明实施例提供的区块验证装置的结构图;

图4为本发明另一实施例提供的区块验证装置的结构图。

具体实施方式

图1为本发明实施例提供的区块验证方法流程图。本发明实施例针对用户终端例如手机等往往不具备作为完整区块链节点的能力,当其他节点发送给用户终端一个区块的时候,用户终端无法验证该区块的真伪,提供了区块验证方法,该方法具体步骤如下:

步骤s101、接收根节点发送的区块的标识信息、哈希值和签名信息,所述签名信息是采用所述根节点的私钥对所述区块的标识信息、哈希值进行签名后得到的。

本实施例的执行主体具体可以是区块链网络中的移动终端节点,例如智能终端类节点,智能终端类节点在区块链网络中并不是始终在线。如图2所示,区块链网络中包括记账节点、根节点、服务器节点和移动终端节点,其中,记账节点具有记账权,可生成新的区块,并将新的区块广播到区块链网络中。根节点也叫做创始节点,用于创造创世区块。服务器节点也叫做完整节点,完整节点是指一直在区块链网络中在线的,并保存有完整的区块链账本的节点。移动终端节点也叫做不完整节点,不完整节点是指不一直在区块链网络中在线的节点,该移动终端节点功能如下:交易的发起和确认,电子合同的签署,存储本节点的私钥,该移动终端节点一般都在区块链网络中有一个自己的代理节点,该代理节点是一个一直在区块链网络中在线的替移动终端节点执行某些功能的节点,代理节点替移动终端节点执行的某些功能包括:接入p2p网络,进行广播消息的发送接收和处理,记账权的获取计算和抢夺,获取相应的奖励(例如比特币旷工挖矿的奖励),存储本节点的公钥等。

如图2所示,记账节点生成新的区块,并将新的区块广播到区块链网络中,根节点和服务器节点均可接收到该新的区块。当根节点接收到该新的区块后,提取该新的区块的区块号和哈希值,例如,新的区块的区块号为n,新的区块的哈希值为hash-n,进一步的,根节点采用该根节点的私钥对新的区块的区块号、新的区块的哈希值为hash-n进行签名,并将签名后的签名信息和签名前的区块号和区块哈希值广播到区块链网络中,服务器节点和移动终端节点均可以接收到根节点广播的区块号、区块哈希值和签名信息。

当服务器节点接收到该新的区块时,根据根节点广播的区块号、区块哈希值和签名信息对该区块进行验证,具体的验证过程为:服务器节点根据其预先存储的根节点的公钥对该签名信息进行验证,如果验证通过,则服务器节点将该新的区块更新到完整的区块链账本。

步骤s102、根据所述根节点的公钥对所述签名信息进行验证,若验证成功,则存储所述区块的标识信息、哈希值和签名信息的对应关系。

当移动终端节点均接收到根节点广播的区块号、区块哈希值和签名信息之后,根据移动终端节点预先存储的根节点的公钥对该签名信息进行验证,若验证通过,则将根节点广播的区块号、区块哈希值和签名信息的对应关系存储在移动终端节点本地。

具体的,所述存储所述区块的标识信息、哈希值和签名信息的对应关系,包括:将所述区块的标识信息、哈希值和签名信息的对应关系存储到签名索引表中。例如,移动终端节点本地创建有一个签名索引表,该签名索引表存储有根节点广播的每个区块的区块号、区块哈希值和签名信息,具体的,对于一个区块的区块号、区块哈希值和签名信息,移动终端节点可以在该签名索引表中创建一个条目。

步骤s103、从服务器节点获取所需查询的区块,并计算所述区块的哈希值。

所述从服务器节点获取所需查询的区块,包括:向所述服务器节点发送区块获取请求,以使所述服务器节点从区块链账本中获取获取所需查询的区块;接收所述服务器发送的所需查询的区块。

当移动终端节点需要查询某个区块时,向服务器节点发送区块获取请求,该区块获取请求中可以包括该移动终端节点需要查询的区块的标识信息,例如所需查询的区块的区块号。服务器节点接收到该区块获取请求后,从完整的区块链账本中获取该区块号对应的区块,即获取移动终端节点需要查询的区块,并将该区块发送给移动终端节点,例如,区块n为移动终端节点需要查询的区块。

步骤s104、比较计算出的所述区块的哈希值和所述区块中携带的哈希值是否一致。

移动终端节点从服务器节点获取到区块n之后,首先计算区块n的哈希值,并比较计算得到的区块n的哈希值和区块n中携带的哈希值是否一致,具体的,区块n的区块头中携带有哈希值。如果移动终端节点计算得到的区块n的哈希值和区块n中携带的哈希值一致,则继续执行后续步骤,如果不一致,则对该区块验证失败。

步骤s105、若一致,则通过比较所述区块中携带的哈希值和本地存储的所述区块的哈希值是否一致,对所述区块进行验证。

如果移动终端节点计算得到的区块n的哈希值和区块n中携带的哈希值一致,则移动终端节点继续比较区块n中携带的哈希值和本地存储的区块n的哈希值是否一致,具体的,移动终端节点可以比较区块n中携带的哈希值和签名索引表中存储的区块n的哈希值是否一致。

若所述区块中携带的哈希值和所述签名索引表中存储的所述区块的哈希值一致,则对所述区块验证成功。若所述区块中携带的哈希值和所述签名索引表中存储的所述区块的哈希值不一致,则对所述区块验证失败。

本发明实施例通过移动终端节点接收根节点发送的区块的标识信息、哈希值和签名信息,并存储所述区块的标识信息、哈希值和签名信息的对应关系,当移动终端节点从服务器节点获取到所需查询的区块之后,通过比较该区块中携带的哈希值和本地存储的该区块的哈希值是否一致,以实现对该区块的验证。

图3为本发明实施例提供的区块验证装置的结构图。本发明实施例提供的区块验证装置可以执行区块验证方法实施例提供的处理流程,如图3所示,区块验证装置30包括:接收模块31、验证模块32、存储模块33、获取模块34、计算模块35、比较模块36;其中,接收模块31用于接收根节点发送的区块的标识信息、哈希值和签名信息,所述签名信息是采用所述根节点的私钥对所述区块的标识信息、哈希值进行签名后得到的;验证模块32用于根据所述根节点的公钥对所述签名信息进行验证;存储模块33用于当验证模块32根据所述根节点的公钥对所述签名信息验证成功时,存储所述区块的标识信息、哈希值和签名信息的对应关系;获取模块34用于从服务器节点获取所需查询的区块;计算模块35用于计算所述区块的哈希值;比较模块36用于比较计算出的所述区块的哈希值和所述区块中携带的哈希值是否一致;若一致,则比较所述区块中携带的哈希值和本地存储的所述区块的哈希值是否一致;验证模块32根据比较模块36的比较结果对所述区块进行验证。

本发明实施例提供的区块验证装置可以具体用于执行上述图1所提供的方法实施例,具体功能此处不再赘述。

本发明实施例通过移动终端节点接收根节点发送的区块的标识信息、哈希值和签名信息,并存储所述区块的标识信息、哈希值和签名信息的对应关系,当移动终端节点从服务器节点获取到所需查询的区块之后,通过比较该区块中携带的哈希值和本地存储的该区块的哈希值是否一致,以实现对该区块的验证。

图4为本发明另一实施例提供的区块验证装置的结构图。在上述实施例的基础上,区块验证装置30还包括:发送模块37,发送模块37用于向所述服务器节点发送区块获取请求,以使所述服务器节点从区块链账本中获取获取所需查询的区块;接收模块31还用于接收所述服务器发送的所需查询的区块。

存储模块33具体用于:将所述区块的标识信息、哈希值和签名信息的对应关系存储到签名索引表中。

若所述区块中携带的哈希值和所述签名索引表中存储的所述区块的哈希值一致,则验证模块32对所述区块验证成功。

若所述区块中携带的哈希值和所述签名索引表中存储的所述区块的哈希值不一致,则验证模块32对所述区块验证失败。

本发明实施例提供的区块验证装置可以具体用于执行上述图2所提供的方法实施例,具体功能此处不再赘述。

本发明实施例通过移动终端节点接收根节点发送的区块的标识信息、哈希值和签名信息,并存储所述区块的标识信息、哈希值和签名信息的对应关系,当移动终端节点从服务器节点获取到所需查询的区块之后,通过比较该区块中携带的哈希值和本地存储的该区块的哈希值是否一致,以实现对该区块的验证。

综上所述,本发明实施例通过移动终端节点接收根节点发送的区块的标识信息、哈希值和签名信息,并存储所述区块的标识信息、哈希值和签名信息的对应关系,当移动终端节点从服务器节点获取到所需查询的区块之后,通过比较该区块中携带的哈希值和本地存储的该区块的哈希值是否一致,以实现对该区块的验证。

在本发明所提供的几个实施例中,应该理解到,所揭露的装置和方法,可以通过其它的方式实现。例如,以上所描述的装置实施例仅仅是示意性的,例如,所述单元的划分,仅仅为一种逻辑功能划分,实际实现时可以有另外的划分方式,例如多个单元或组件可以结合或者可以集成到另一个系统,或一些特征可以忽略,或不执行。另一点,所显示或讨论的相互之间的耦合或直接耦合或通信连接可以是通过一些接口,装置或单元的间接耦合或通信连接,可以是电性,机械或其它的形式。

所述作为分离部件说明的单元可以是或者也可以不是物理上分开的,作为单元显示的部件可以是或者也可以不是物理单元,即可以位于一个地方,或者也可以分布到多个网络单元上。可以根据实际的需要选择其中的部分或者全部单元来实现本实施例方案的目的。

另外,在本发明各个实施例中的各功能单元可以集成在一个处理单元中,也可以是各个单元单独物理存在,也可以两个或两个以上单元集成在一个单元中。上述集成的单元既可以采用硬件的形式实现,也可以采用硬件加软件功能单元的形式实现。

上述以软件功能单元的形式实现的集成的单元,可以存储在一个计算机可读取存储介质中。上述软件功能单元存储在一个存储介质中,包括若干指令用以使得一台计算机设备(可以是个人计算机,服务器,或者网络设备等)或处理器(processor)执行本发明各个实施例所述方法的部分步骤。而前述的存储介质包括:u盘、移动硬盘、只读存储器(read-onlymemory,rom)、随机存取存储器(randomaccessmemory,ram)、磁碟或者光盘等各种可以存储程序代码的介质。

本领域技术人员可以清楚地了解到,为描述的方便和简洁,仅以上述各功能模块的划分进行举例说明,实际应用中,可以根据需要而将上述功能分配由不同的功能模块完成,即将装置的内部结构划分成不同的功能模块,以完成以上描述的全部或者部分功能。上述描述的装置的具体工作过程,可以参考前述方法实施例中的对应过程,在此不再赘述。

最后应说明的是:以上各实施例仅用以说明本发明的技术方案,而非对其限制;尽管参照前述各实施例对本发明进行了详细的说明,本领域的普通技术人员应当理解:其依然可以对前述各实施例所记载的技术方案进行修改,或者对其中部分或者全部技术特征进行等同替换;而这些修改或者替换,并不使相应技术方案的本质脱离本发明各实施例技术方案的范围。

当前第1页1 2 
网友询问留言 已有0条留言
  • 还没有人留言评论。精彩留言会获得点赞!
1