区块链交易信息正确性的校验方法、装置及系统与流程

文档序号:12125718阅读:1303来源:国知局
区块链交易信息正确性的校验方法、装置及系统与流程

本发明涉及互联网技术领域,特别是涉及一种区块链交易信息正确性的校验方法、装置及系统。



背景技术:

随着信息技术的不断发展,互联网的应用也越来越普及,例如,用户可以通过互联网进行网上交易。在通过互联网进行网上交易时,每一笔网上交易一般对应一条或多条交易信息,而交易信息可以反映出用户的交易行为。因此,如何对交易信息进行保存十分关键。

在区块链技术中,客户平台生成的交易信息是由具有写入权限的矿机代理写入区块链中实现保存的。具体的,当某客户平台需要将交易信息写入区块链中时,先将该交易信息发送给矿机,然后由该矿机将接收到的交易信息写入区块链中,最后再将写入区块链中的新区块同步至点对点网络中的各个客户平台。

然而,由于所有的交易信息均需要通过矿机代理写入区块链,所以若该矿机将交易信息进行篡改后再写入区块链中,则会造成写入区块链中的交易信息的可靠性和准确性降低。



技术实现要素:

有鉴于此,本发明提供一种区块链交易信息正确性的校验方法、装置及系统,能够对矿机写入区块链中的交易信息进行正确性校验。

本发明的目的是采用以下技术方案来实现的:

第一方面,本发明提供了一种区块链交易信息正确性的校验方法,所述方法应用于矿机,所述方法包括:

接收信息录入客户平台发送的交易信息和所述交易信息对应的签名信息,所述交易信息由客户端发起的交易操作生成,所述签名信息是通过所述信息录入客户平台存储的私钥对所述交易信息的运算值进行签名得到的,所述交易信息的运算值根据预设算法进行运算而得;

将包含所述交易信息和所述签名信息的新区块写入区块链中;

将写入所述区块链中的所述新区块发送给点对点网络中的各个客户平台,以便所述各个客户平台根据所述新区块中的签名信息对对应的交易信息的正确性进行校验,所述各个客户平台包括所述信息录入客户平台和信息读取客户平台。

结合第一方面,在第一方面的第一种可能的实现方式中,在将包含所述交易信息和所述签名信息的新区块写入区块链中之前,所述方法还包括:

根据所述预设算法对接收到的交易信息进行运算,获得所述交易信息的运算值;

根据所述交易信息的运算值、所述签名信息以及所述私钥对应的公钥进行验签;

所述将包含所述交易信息和所述签名信息的新区块写入区块链中包括:

若验签成功,则将包含所述交易信息和所述签名信息的新区块写入区块链中。

结合第一方面的第一种可能的实现方式,在第一方面的第二种可能的实现方式中,所述方法还包括:

若验签失败,则删除所述交易信息以及所述签名信息,并输出用于提示接收到的交易信息存在异常的提示信息。

结合第一方面的第一种可能的实现方式,在第一方面的第三种可能的实现方式中,所述方法还包括:

若验签失败,则向所述信息录入客户平台发送重发指令,以便所述信息录入客户平台根据所述重发指令重新发送交易信息以及所述交易信息对应的签名信息。

结合第一方面的第一种可能的实现方式,在第一方面的第四种可能的实现方式中,所述根据所述交易信息的运算值、所述签名信息以及所述私钥对应的公钥进行验签包括:

利用所述公钥对所述签名信息进行解密,获得解密后的运算值;

将所述交易信息的运算值与所述解密后的运算值进行比较;

若两者相同,则确定验签成功;

若两者不同,则确定验签失败。

结合第一方面,在第一方面的第五种可能的实现方式中,在接收信息录入客户平台发送的交易信息和所述交易信息对应的签名信息之前,所述方法还包括:

接收所述信息录入客户平台发送的身份验证请求,所述身份验证请求中携带有所述信息录入客户平台的身份标识信息;

所述接收信息录入客户平台发送的交易信息和所述交易信息对应的签名信息包括:

若确认保存有所述信息录入客户平台的身份标识信息,则接收所述信息录入客户平台发送的交易信息和所述交易信息对应的签名信息。

结合第一方面或第一方面的第一种至第五种任一项可能的实现方式,在第一方面的第六种可能的实现方式中,所述信息录入客户平台存储的私钥为发起交易操作的客户端发送的私钥,或者为所述信息录入客户平台的私钥。

第二方面,本发明提供了一种区块链交易信息正确性的校验方法,所述方法应用于信息录入客户平台或者信息读取客户平台,所述方法包括:

接收矿机通过点对点网络发送的写入区块链中的新区块,所述新区块包括所述矿机接收到的信息录入客户平台发送的交易信息和所述交易信息对应的签名信息,所述信息录入客户平台发送的签名信息是通过所述信息录入客户平台存储的私钥对交易信息的运算值进行签名得到的,所述交易信息的运算值根据预设算法进行运算而得;

从所述新区块中提取交易信息和所述交易信息对应的签名信息;

根据所述预设算法对提取的交易信息进行运算,获得所述提取的交易信息的运算值;

根据所述提取的交易信息的运算值、提取的签名信息以及所述私钥对应的公钥进行验签;

若验签成功,则确定所述新区块中的交易信息正确。

结合第二方面,在第二方面的第一种可能的实现方式中,所述根据所述提取的交易信息的运算值、提取的签名信息以及所述私钥对应的公钥进行验签包括:

利用所述公钥对所述提取的签名信息进行解密,获得解密后的运算值;

将所述提取的交易信息的运算值与所述解密后的运算值进行比较;

若两者相同,则确定验签成功;

若两者不同,则确定验签失败。

结合第二方面或者第二方面的第一种可能的实现方式,在第二方面的第二种可能的实现方式中,所述信息录入客户平台存储的私钥为发起交易操作的客户端发送的私钥,或者为所述信息录入客户平台的私钥。

第三方面,本发明提供了一种区块链交易信息正确性的校验装置,所述装置应用于矿机,所述装置包括:

接收单元,用于接收信息录入客户平台发送的交易信息和所述交易信息对应的签名信息,所述交易信息由客户端发起的交易操作生成,所述签名信息是通过所述信息录入客户平台存储的私钥对所述交易信息的运算值进行签名得到的,所述交易信息的运算值根据预设算法进行运算而得;

写入单元,用于将包含所述接收单元接收的所述交易信息和所述签名信息的新区块写入区块链中;

发送单元,用于将所述写入单元写入所述区块链中的所述新区块发送给点对点网络中的各个客户平台,以便所述各个客户平台根据所述新区块中的签名信息对对应的交易信息的正确性进行校验,所述各个客户平台包括所述信息录入客户平台和信息读取客户平台。

结合第三方面,在第三方面的第一种可能的实现方式中,所述装置还包括:

运算单元,用于在所述写入单元将包含所述交易信息和所述签名信息的新区块写入区块链中之前,根据所述预设算法对接收到的交易信息进行运算,获得所述交易信息的运算值;

验签单元,用于根据所述运算单元获得的所述交易信息的运算值、所述签名信息以及所述私钥对应的公钥进行验签;

所述写入单元还用于当所述验签单元验签成功时,将包含所述交易信息和所述签名信息的新区块写入区块链中。

结合第三方面的第一种可能的实现方式,在第三方面的第二种可能的实现方式中,所述装置还包括:

删除单元,用于当所述验签单元验签失败时,删除所述交易信息以及所述签名信息;

输出单元,用于输出用于提示接收到的交易信息存在异常的提示信息。

结合第三方面的第一种可能的实现方式,在第三方面的第三种可能的实现方式中,所述发送单元还用于当所述验签单元验签失败时,向所述信息录入客户平台发送重发指令,以便所述信息录入客户平台根据所述重发指令重新发送交易信息以及所述交易信息对应的签名信息。

结合第三方面的第一种可能的实现方式,在第三方面的第四种可能的实现方式中,所述验签单元包括:

解密模块,用于利用所述公钥对所述签名信息进行解密,获得解密后的运算值;

比较模块,用于将所述交易信息的运算值与所述解密模块解密后的运算值进行比较;

确定模块,用于当所述比较模块的比较结果为两者相同时,确定验签成功;当所述比较模块的比较结果为两者不同时,确定验签失败。

结合第三方面,在第三方面的第五种可能的实现方式中,所述接收单元还用于在接收信息录入客户平台发送的交易信息和所述交易信息对应的签名信息之前,接收所述信息录入客户平台发送的身份验证请求,所述身份验证请求中携带有所述信息录入客户平台的身份标识信息;

所述接收单元还用于当确认保存有所述信息录入客户平台的身份标识信息时,接收所述信息录入客户平台发送的交易信息和所述交易信息对应的签名信息。

结合第三方面或第三方面的第一种至第五种任一项可能的实现方式,在第三方面的第六种可能的实现方式中,所述信息录入客户平台存储的私钥为发起交易操作的客户端发送的私钥,或者为所述信息录入客户平台的私钥。

第四方面,本发明提供了一种区块链交易信息正确性的校验装置,所述装置应用于信息录入客户平台或者信息读取客户平台,所述装置包括:

接收单元,用于接收矿机通过点对点网络发送的写入区块链中的新区块,所述新区块包括所述矿机接收到的信息录入客户平台发送的交易信息和所述交易信息对应的签名信息,所述信息录入客户平台发送的签名信息是通过所述信息录入客户平台存储的私钥对交易信息的运算值进行签名得到的,所述交易信息的运算值根据预设算法进行运算而得;

提取单元,用于从所述接收单元接收到的所述新区块中提取交易信息和所述交易信息对应的签名信息;

运算单元,用于根据所述预设算法对提取的交易信息进行运算,获得所述提取的交易信息的运算值;

验签单元,用于根据所述运算单元获得的所述提取的交易信息的运算值、提取的签名信息以及所述私钥对应的公钥进行验签;

确定单元,用于当所述验签单元验签成功时,确定所述新区块中的交易信息正确。

结合第四方面,在第四方面的第一种可能的实现方式中,所述验签单元包括:

解密模块,用于利用所述公钥对所述提取的签名信息进行解密,获得解密后的运算值;

比较模块,用于将所述提取的交易信息的运算值与所述解密模块解密后的运算值进行比较;

确定模块,用于当所述比较模块的比较结果为两者相同时,确定验签成功;当所述比较模块的比较结果为两者不同时,确定验签失败。

结合第四方面或者第四方面的第一种可能的实现方式,在第四方面的第二种可能的实现方式中,所述信息录入客户平台存储的私钥为发起交易操作的客户端发送的私钥,或者为所述信息录入客户平台的私钥。

第五方面,本发明提供了一种区块链交易信息正确性的校验系统,所述系统包括矿机、信息录入客户平台以及信息读取客户平台;其中,所述矿机包括如第三方面或者第三方面的第一种至第六种任一项可能实现方式所述的装置;所述信息录入客户平台或者信息读取客户平台包括如第四方面或者第四方面的第一种至第二种任一项可能实现方式所述的装置。

借由上述技术方案,本发明提供的区块链交易信息正确性的校验方法、装置及系统,能够在信息录入客户平台向矿机发送交易信息的同时,还会发送该交易信息对应的签名信息,从而使得矿机在往区块链中写入数据时,可以将包括交易信息和与其对应的签名信息的新区块写入区块链中,进而在矿机将新区块发送至各个客户平台后,客户平台可以根据新区块中的签名信息来对新区块中的交易信息进行正确性校验,由此可以让用户可以获知矿机写入区块链中的交易信息是否被篡改。

上述说明仅是本发明技术方案的概述,为了能够更清楚了解本发明的技术手段,而可依照说明书的内容予以实施,并且为了让本发明的上述和其它目的、特征和优点能够更明显易懂,以下特举本发明的具体实施方式。

附图说明

通过阅读下文优选实施方式的详细描述,各种其他的优点和益处对于本领域普通技术人员将变得清楚明了。附图仅用于示出优选实施方式的目的,而并不认为是对本发明的限制。而且在整个附图中,用相同的参考符号表示相同的部件。在附图中:

图1示出了本发明实施例提供的一种区块链交易信息正确性的校验方法的流程图;

图2示出了本发明实施例提供的另一种区块链交易信息正确性的校验方法的流程图;

图3示出了本发明实施例提供的一种区块链交易信息校验的场景示意图;

图4示出了本发明实施例提供的一种区块链交易信息正确性的校验装置的组成框图;

图5示出了本发明实施例提供的另一种区块链交易信息正确性的校验装置的组成框图;

图6示出了本发明实施例提供的另一种区块链交易信息正确性的校验装置的组成框图;

图7示出了本发明实施例提供的另一种区块链交易信息正确性的校验装置的组成框图;

图8示出了本发明实施例提供的一种区块链交易信息正确性的校验系统的示意图。

具体实施方式

下面将参照附图更详细地描述本公开的示例性实施例。虽然附图中显示了本公开的示例性实施例,然而应当理解,可以以各种形式实现本公开而不应被这里阐述的实施例所限制。相反,提供这些实施例是为了能够更透彻地理解本公开,并且能够将本公开的范围完整的传达给本领域的技术人员。

本发明实施例提供了一种区块链交易信息正确性的校验方法,所述方法主要应用于矿机,如图1所示,所述方法主要包括:

101、接收信息录入客户平台发送的交易信息和所述交易信息对应的签名信息;

其中,交易信息是由客户端发起的交易操作生成的交易完整记录,主要包括用户ID(Identity,身份标识号码)、项目ID、交易金额、交易时间、客户平台ID等信息。例如,用户基于客户端对项目1投资100元时,客户端会将当前用户的用户ID、项目1的ID以及交易金额100发送给与之对应的服务器(即信息录入客户平台),信息录入客户平台接收到这些信息后,会生成对应的、包括用户ID、项目1ID、100元、交易时间、客户平台ID的完整交易记录。另外,交易信息的具体表现形式可以为记录条,也可以为其他形式,本发明实施例对此不做限定。

签名信息是通过信息录入客户平台存储的私钥对交易信息的运算值进行签名得到的,交易信息的运算值根据预设算法进行运算而得。其中,预设算法可以为哈希算法,也可以为其他算法;相应地,运算值可以为哈希值,也可以为其他数值。另外,签名信息具体可以根据需求配置在交易信息的不同位置,例如,可以将签名信息配置在交易信息的头部、尾部等,本发明实施例不做限定。

需要说明的是,信息录入客户平台存储的私钥可以为发起交易操作的客户端发送的私钥,也可以为信息录入客户平台的私钥,具体可以根据具体应用而定,本发明实施例对此不进行限制。例如,当信息录入客户平台所服务的用户较少时,可以直接使用信息录入客户平台的私钥作为签名时所需的私钥;当信息录入客户平台所服务的用户较多时,为了保证用户交易信息的安全性,可以使用用户基于客户端设置的私钥作为签名时所需的私钥。

需要补充的是,本发明实施例应用于点对点网络中,且点对点网络中包括至少一个客户平台,每个客户平台均有信息录入和信息读取的权限,即每个客户平台既可以作为信息录入客户平台,又可以作为信息读取客户平台。当某客户平台产生交易信息时,就作为信息录入客户平台,而其他客户平台则作为信息读取客户平台。

102、将包含所述交易信息和所述签名信息的新区块写入区块链中;

其中,区块链是一串使用密码学方法相关联产生的数据块,每一个数据块中包含了过去一段预定时间内所有的交易信息,用于验证其信息的有效性和生成下一个区块。矿机接收到信息录入客户平台发送的交易信息和该交易信息对应的签名信息后,可以将交易信息、签名信息、时间戳、上一区块的运算值(如哈希值)等信息记录为一个新区块与上一区块进行连接,从而写入区块链中。

103、将写入所述区块链中的所述新区块发送给点对点网络中的各个客户平台,以便所述各个客户平台根据所述新区块中的签名信息对对应的交易信息的正确性进行校验。

其中,点对点网络中的各个客户平台包括信息录入客户平台和信息读取客户平台。在区块链中写入新区块后,需要将新区块同步至点对点中的各个客户平台,以便用户可以基于任一客户平台查询区块链中新产生的交易信息。在客户平台接收到新区块后,可以利用信息录入客户平台签名时所使用的私钥对应的公钥、签名信息以及新区块中的交易信息的运算值(即通过预设算法运算而得)进行验签操作,并在验签成功时,确定新区块中记录的交易信息与信息录入客户平台产生的交易信息相同,并没有被矿机篡改。其中,各个客户平台的验签过程详见下述实施例中的步骤203-204。

本发明实施例提供的区块链交易信息正确性的校验方法,能够在信息录入客户平台向矿机发送交易信息的同时,还会发送该交易信息对应的签名信息,从而使得矿机在往区块链中写入数据时,可以将包括交易信息和与其对应的签名信息的新区块写入区块链中,进而在矿机将新区块发送至各个客户平台后,客户平台可以根据新区块中的签名信息来对新区块中的交易信息进行正确性校验,由此可以让用户可以获知矿机写入区块链中的交易信息是否被篡改。

进一步的,当矿机没有篡改所接收到的交易信息时,也可能因接收到的交易信息本身就是被篡改后的信息,而导致写入区块链的交易信息不正确的现象。因此,为了防止接收到的交易信息被篡改的情况下,矿机依然将其写入区块链中,从而导致区块链的可靠性降低,可以采用如下改进方案:

在将包含所述交易信息和所述签名信息的新区块写入区块链中之前,先根据所述预设算法对接收到的交易信息进行运算,获得所述交易信息的运算值;然后根据所述交易信息的运算值、所述签名信息以及所述私钥对应的公钥进行验签;若验签成功,则将包含所述交易信息和所述签名信息的新区块写入区块链中;若验签失败,则不将包含所述交易信息和所述签名信息的新区块写入区块链中。

其中,步骤“根据所述交易信息的运算值、所述签名信息以及所述私钥对应的公钥进行验签”的具体实现方式可以为:利用所述公钥对所述签名信息进行解密,获得解密后的运算值;将所述交易信息的运算值与所述解密后的运算值进行比较;若两者相同,则确定验签成功;若两者不同,则确定验签失败。

进一步的,为了防止错误的交易信息占用矿机的存储空间,在确定验签失败后,可以将接收到的交易信息和签名信息删除。为了提示矿机的管理员及时获知矿机接收到的交易信息存在异常,还可以输出用于提示接收到的交易信息存在异常的提示信息。为了在确定验签失败的情况下,继续获得正确的的交易信息,可以在确定验签失败后,向信息录入客户平台发送重发指令,以便信息录入客户平台根据该重发指令重新发送交易信息以及该交易信息对应的签名信息。

进一步的,为了防止非法客户平台与矿机进行交互,从而导致非法交易信息写入区块链,矿机可以先对信息录入客户平台的身份进行验证,当确定其身份合法时,再接收其发送的交易信息和签名信息。

具体的,在接收信息录入客户平台发送的交易信息和所述交易信息对应的签名信息之前,矿机可以先接收所述信息录入客户平台发送的身份验证请求,所述身份验证请求中携带有所述信息录入客户平台的身份标识信息;若确认保存有所述信息录入客户平台的身份标识信息,则接收所述信息录入客户平台发送的交易信息和所述交易信息对应的签名信息。

其中,身份标识信息用于唯一标识客户平台的身份,具体可以为客户平台名、端口IP地址等,本发明实施例不做限定。

此外,矿机中还存储有预先注册的用户ID,在接收到信息录入客户平台发送的交易信息和签名信息后,可以从交易信息中获取用户ID,然后判断该用户ID是否为预先注册的用户ID,由此来验证用户身份的合法性,并且当确定该用户ID合法时,才将交易信息和签名信息写入区块链中。

进一步的,依据图1所示的方法,本发明的另一个实施例还提供了一种区块链交易信息正确性的校验方法,所述方法主要应用于信息录入客户平台或者信息读取客户平台,如图2所示,所述方法主要包括:

201、接收矿机通过点对点网络发送的写入区块链中的新区块;

具体的,所述新区块包括所述矿机接收到的信息录入客户平台发送的交易信息和所述交易信息对应的签名信息。其中,关于交易信息的具体内容详见上述步骤101的详细描述,在此不再赘述。

此外,所述信息录入客户平台发送的签名信息是通过所述信息录入客户平台存储的私钥对交易信息的运算值进行签名得到的,所述交易信息的运算值根据预设算法进行运算而得。其中,所述信息录入客户平台存储的私钥可以为发起交易操作的客户端发送的私钥,也可以为所述信息录入客户平台的私钥;预设算法可以为哈希算法,也可以为其他算法。

202、从所述新区块中提取交易信息和所述交易信息对应的签名信息;

203、根据所述预设算法对提取的交易信息进行运算,获得所述提取的交易信息的运算值;

其中,当所述预设算法为哈希算法时,本步骤具体为:根据哈希算法对提取的交易信息进行运算,获得该交易信息的哈希值。

204、根据所述提取的交易信息的运算值、提取的签名信息以及所述私钥对应的公钥进行验签;

具体的,信息录入客户平台或者信息读取客户平台先利用所述公钥对所述提取的签名信息进行解密,获得解密后的运算值;然后将所述提取的交易信息的运算值与所述解密后的运算值进行比较;若两者相同,则确定验签成功;若两者不同,则确定验签失败。

当预设算法为哈希算法时,本步骤具体可以为:先利用信息录入客户平台签名时所使用的私钥对应的公钥对提取的签名信息进行解密,获得解密后的哈希值;然后将提取的交易信息的哈希值与解密后的哈希值进行比较;若这两个哈希值相同,则确定验签成功;若这两个哈希值不相同,则确定验签失败。

需要补充的是,信息读取客户平台获取所述私钥对应的公钥的具体实现方式可以为:(1)信息录入客户平台在获得交易信息的签名信息后,将签名时所使用的私钥对应的公钥广播给各个信息读取客户平台;(2)矿机在将新区块发送给信息读取客户平台时,也将验签所需的公钥发送给信息读取客户平台。

205、若验签成功,则确定所述新区块中的交易信息正确。

当验签成功时,信息录入客户平台或者信息读取客户平台可以确定新区块中记录的交易信息与信息录入客户平台发送给矿机的交易信息相同,从而确定新区块中的交易信息正确;当验签失败时,可以确定新区块中记录的交易信息与信息录入客户平台发送给矿机的交易信息不相同,从而确定新区块中的交易信息错误。

本发明实施例提供的区块链交易信息正确性的校验方法,能够在信息录入客户平台向矿机发送交易信息的同时,还会发送该交易信息对应的签名信息,从而使得矿机在往区块链中写入数据时,可以将包括交易信息和与其对应的签名信息的新区块写入区块链中,进而在矿机将新区块发送至各个客户平台后,客户平台可以根据新区块中的签名信息来对新区块中的交易信息进行正确性校验,由此可以让用户可以获知矿机写入区块链中的交易信息是否被篡改。

通过上述实施例可知,以哈希算法进行运算为例,在实现区块链交易信息正确性校验的过程中,涉及的签名和验签过程可以如图3所示。具体的,当信息录入客户平台生成交易信息后,可以利用哈希算法对该交易信息进行哈希运算,获得哈希值,然后利用存储的私钥对该哈希值进行签名,获得交易信息对应的签名信息,并将交易信息和签名信息发送给矿机;矿机接收到信息录入客户平台发送的交易信息和签名信息后,将包括交易信息和签名信息的区块n与区块n-1进行连接,从而使得交易信息和签名信息写入区块链中,然后通过点对点网络将区块n发送给各个客户平台;客户平台(包括信息录入客户平台和信息读取客户平台)接收到矿机发送的区块n后,先从区块n中提取交易信息和签名信息,然后利用哈希算法对提取的交易信息进行哈希运算获得哈希值,最后根据信息录入客户平台进行签名时所使用的私钥所对应的公钥、提取的交易信息的哈希值以及签名信息进行验签操作,从而确定区块n中的交易信息是否正确。

进一步的,依据图1所示的方法,本发明实施例提供了一种区块链交易信息正确性的校验装置,所述装置主要应用于矿机,如图4所示,所述装置包括:

接收单元31,用于接收信息录入客户平台发送的交易信息和所述交易信息对应的签名信息,所述交易信息由客户端发起的交易操作生成,所述签名信息是通过所述信息录入客户平台存储的私钥对所述交易信息的运算值进行签名得到的,所述交易信息的运算值根据预设算法进行运算而得;

写入单元32,用于将包含所述接收单元31接收的所述交易信息和所述签名信息的新区块写入区块链中;

发送单元33,用于将所述写入单元32写入所述区块链中的所述新区块发送给点对点网络中的各个客户平台,以便所述各个客户平台根据所述新区块中的签名信息对对应的交易信息的正确性进行校验,所述各个客户平台包括所述信息录入客户平台和信息读取客户平台。

进一步的,如图5所示,所述装置还包括:

运算单元34,用于在所述写入单元32将包含所述交易信息和所述签名信息的新区块写入区块链中之前,根据所述预设算法对接收到的交易信息进行运算,获得所述交易信息的运算值;

验签单元35,用于根据所述运算单元34获得的所述交易信息的运算值、所述签名信息以及所述私钥对应的公钥进行验签;

所述写入单元32还用于当所述验签单元35验签成功时,将包含所述交易信息和所述签名信息的新区块写入区块链中。

进一步的,如图5所示,所述装置还包括:

删除单元36,用于当所述验签单元35验签失败时,删除所述交易信息以及所述签名信息;

输出单元37,用于输出用于提示接收到的交易信息存在异常的提示信息。

进一步的,所述发送单元33还用于当所述验签单元35验签失败时,向所述信息录入客户平台发送重发指令,以便所述信息录入客户平台根据所述重发指令重新发送交易信息以及所述交易信息对应的签名信息。

进一步的,如图5所示,所述验签单元35包括:

解密模块351,用于利用所述公钥对所述签名信息进行解密,获得解密后的运算值;

比较模块352,用于将所述交易信息的运算值与所述解密模块351解密后的运算值进行比较;

确定模块353,用于当所述比较模块352的比较结果为两者相同时,确定验签成功;当所述比较模块352的比较结果为两者不同时,确定验签失败。

进一步的,所述接收单元31还用于在接收信息录入客户平台发送的交易信息和所述交易信息对应的签名信息之前,接收所述信息录入客户平台发送的身份验证请求,所述身份验证请求中携带有所述信息录入客户平台的身份标识信息;

所述接收单元31还用于当确认保存有所述信息录入客户平台的身份标识信息时,接收所述信息录入客户平台发送的交易信息和所述交易信息对应的签名信息。

进一步的,所述信息录入客户平台存储的私钥为发起交易操作的客户端发送的私钥,或者为所述信息录入客户平台的私钥。

本发明实施例提供的区块链交易信息正确性的校验装置,能够在信息录入客户平台向矿机发送交易信息的同时,还会发送该交易信息对应的签名信息,从而使得矿机在往区块链中写入数据时,可以将包括交易信息和与其对应的签名信息的新区块写入区块链中,进而在矿机将新区块发送至各个客户平台后,客户平台可以根据新区块中的签名信息来对新区块中的交易信息进行正确性校验,由此可以让用户可以获知矿机写入区块链中的交易信息是否被篡改。

进一步的,依据图2所示的方法,本发明的另一个实施例还提供了一种区块链交易信息正确性的校验装置,所述装置应用于信息录入客户平台或者信息读取客户平台,如图6所示,所述装置主要包括:

接收单元41,用于接收矿机通过点对点网络发送的写入区块链中的新区块,所述新区块包括所述矿机接收到的信息录入客户平台发送的交易信息和所述交易信息对应的签名信息,所述信息录入客户平台发送的签名信息是通过所述信息录入客户平台存储的私钥对交易信息的运算值进行签名得到的,所述交易信息的运算值根据预设算法进行运算而得;

提取单元42,用于从所述接收单元41接收到的所述新区块中提取交易信息和所述交易信息对应的签名信息;

运算单元43,用于根据所述预设算法对提取的交易信息进行运算,获得所述提取的交易信息的运算值;

验签单元44,用于根据所述运算单元43获得的所述提取的交易信息的运算值、提取的签名信息以及所述私钥对应的公钥进行验签;

确定单元45,用于当所述验签单元44验签成功时,确定所述新区块中的交易信息正确。

进一步的,如图7所示,所述验签单元44包括:

解密模块441,用于利用所述公钥对所述提取的签名信息进行解密,获得解密后的运算值;

比较模块442,用于将所述提取的交易信息的运算值与所述解密模块441解密后的运算值进行比较;

确定模块443,用于当所述比较模块442的比较结果为两者相同时,确定验签成功;当所述比较模块442的比较结果为两者不同时,确定验签失败。

进一步的,所述信息录入客户平台存储的私钥为发起交易操作的客户端发送的私钥,或者为所述信息录入客户平台的私钥。

本发明实施例提供的区块链交易信息正确性的校验装置,能够在信息录入客户平台向矿机发送交易信息的同时,还会发送该交易信息对应的签名信息,从而使得矿机在往区块链中写入数据时,可以将包括交易信息和与其对应的签名信息的新区块写入区块链中,进而在矿机将新区块发送至各个客户平台后,客户平台可以根据新区块中的签名信息来对新区块中的交易信息进行正确性校验,由此可以让用户可以获知矿机写入区块链中的交易信息是否被篡改。

进一步的,上述装置实施例,本发明的另一个实施例还提供了一种区块链交易信息正确性的校验系统,如图8所示,所述系统包括矿机51、信息录入客户平台52以及信息读取客户平台53;其中,所述矿机51包括如图4或5所示的装置;所述信息录入客户平台52或者信息读取客户平台53包括如图6或7所示的装置。

本发明实施例提供的区块链交易信息正确性的校验系统,能够在信息录入客户平台向矿机发送交易信息的同时,还会发送该交易信息对应的签名信息,从而使得矿机在往区块链中写入数据时,可以将包括交易信息和与其对应的签名信息的新区块写入区块链中,进而在矿机将新区块发送至各个客户平台后,客户平台可以根据新区块中的签名信息来对新区块中的交易信息进行正确性校验,由此可以让用户可以获知矿机写入区块链中的交易信息是否被篡改。

在上述实施例中,对各个实施例的描述都各有侧重,某个实施例中没有详述的部分,可以参见其他实施例的相关描述。

可以理解的是,上述方法及装置中的相关特征可以相互参考。另外,上述实施例中的“第一”、“第二”等是用于区分各实施例,而并不代表各实施例的优劣。

所属领域的技术人员可以清楚地了解到,为描述的方便和简洁,上述描述的系统,装置和单元的具体工作过程,可以参考前述方法实施例中的对应过程,在此不再赘述。

在此提供的算法和显示不与任何特定计算机、虚拟系统或者其它设备固有相关。各种通用系统也可以与基于在此的示教一起使用。根据上面的描述,构造这类系统所要求的结构是显而易见的。此外,本发明也不针对任何特定编程语言。应当明白,可以利用各种编程语言实现在此描述的本发明的内容,并且上面对特定语言所做的描述是为了披露本发明的最佳实施方式。

在此处所提供的说明书中,说明了大量具体细节。然而,能够理解,本发明的实施例可以在没有这些具体细节的情况下实践。在一些实例中,并未详细示出公知的方法、结构和技术,以便不模糊对本说明书的理解。

类似地,应当理解,为了精简本公开并帮助理解各个发明方面中的一个或多个,在上面对本发明的示例性实施例的描述中,本发明的各个特征有时被一起分组到单个实施例、图、或者对其的描述中。然而,并不应将该公开的方法解释成反映如下意图:即所要求保护的本发明要求比在每个权利要求中所明确记载的特征更多的特征。更确切地说,如下面的权利要求书所反映的那样,发明方面在于少于前面公开的单个实施例的所有特征。因此,遵循具体实施方式的权利要求书由此明确地并入该具体实施方式,其中每个权利要求本身都作为本发明的单独实施例。

本领域那些技术人员可以理解,可以对实施例中的设备中的模块进行自适应性地改变并且把它们设置在与该实施例不同的一个或多个设备中。可以把实施例中的模块或单元或组件组合成一个模块或单元或组件,以及此外可以把它们分成多个子模块或子单元或子组件。除了这样的特征和/或过程或者单元中的至少一些是相互排斥之外,可以采用任何组合对本说明书(包括伴随的权利要求、摘要和附图)中公开的所有特征以及如此公开的任何方法或者设备的所有过程或单元进行组合。除非另外明确陈述,本说明书(包括伴随的权利要求、摘要和附图)中公开的每个特征可以由提供相同、等同或相似目的的替代特征来代替。

此外,本领域的技术人员能够理解,尽管在此所述的一些实施例包括其它实施例中所包括的某些特征而不是其它特征,但是不同实施例的特征的组合意味着处于本发明的范围之内并且形成不同的实施例。例如,在下面的权利要求书中,所要求保护的实施例的任意之一都可以以任意的组合方式来使用。

本发明的各个部件实施例可以以硬件实现,或者以在一个或者多个处理器上运行的软件模块实现,或者以它们的组合实现。本领域的技术人员应当理解,可以在实践中使用微处理器或者数字信号处理器(DSP)来实现根据本发明实施例的区块链交易信息正确性的校验方法、装置及系统中的一些或者全部部件的一些或者全部功能。本发明还可以实现为用于执行这里所描述的方法的一部分或者全部的设备或者装置程序(例如,计算机程序和计算机程序产品)。这样的实现本发明的程序可以存储在计算机可读介质上,或者可以具有一个或者多个信号的形式。这样的信号可以从因特网网站上下载得到,或者在载体信号上提供,或者以任何其他形式提供。

应该注意的是上述实施例对本发明进行说明而不是对本发明进行限制,并且本领域技术人员在不脱离所附权利要求的范围的情况下可设计出替换实施例。在权利要求中,不应将位于括号之间的任何参考符号构造成对权利要求的限制。单词“包含”不排除存在未列在权利要求中的元件或步骤。位于元件之前的单词“一”或“一个”不排除存在多个这样的元件。本发明可以借助于包括有若干不同元件的硬件以及借助于适当编程的计算机来实现。在列举了若干装置的单元权利要求中,这些装置中的若干个可以是通过同一个硬件项来具体体现。单词第一、第二、以及第三等的使用不表示任何顺序。可将这些单词解释为名称。

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