1.本公开涉及区块链技术领域,尤其涉及区块链数据处理方法、装置及存储介质。
背景技术:2.区块链是一种能够通过去中心化和去信任的方式集体维护一个可靠数据库的技术。其能够把一段时间内发生的事务以区块为单位进行存储,并以密码学算法将区块按时间先后顺序连接,形成类似链条的一种数据结构。由于区块链技术具有去中心化、不可篡改等特点,其在诸多方面都有着较高的应用前景。
3.相关场景中,在通过区块链存储大型文件时,还存在着存储效率较低的问题。
技术实现要素:4.为克服相关技术中存在的问题,本公开提供一种区块链数据处理方法、装置及存储介质。
5.根据本公开实施例的第一方面,提供一种区块链数据处理方法,包括:
6.获取交易数据保存请求,所述交易数据保存请求包括交易附件;
7.从区块链网络中的多个数据保存节点中确定多个目标数据保存节点;
8.通过所述目标数据保存节点对所述交易附件进行存储,得到所述交易附件的存储地址;
9.将包括所述存储地址的交易数据保存至所述区块链网络的区块链中。
10.可选地,所述区块链网络中的多个数据保存节点共同构建为分布式文件系统,所述从区块链网络中的多个数据保存节点中确定多个目标数据保存节点,包括:
11.向所述分布式文件系统发送交易附件保存请求,以使得所述分布式文件系统基于预设的节点选取规则,从所述多个数据保存节点中确定多个目标数据保存节点。
12.可选地,所述交易附件保存请求还包括用于描述交易附件备份次数的目标数量值,以使得所述分布式文件系统从所述多个数据保存节点中确定目标数量值个目标数据保存节点。
13.可选地,所述区块链网络中的多个数据保存节点共同构建发布文件保存智能合约,所述从区块链网络中的多个数据保存节点中确定多个目标数据保存节点,包括:
14.基于所述文件保存智能合约中的预设节点选取规则,从所述多个数据保存节点中确定多个目标数据保存节点。
15.可选地,所述交易附件的数量为多个,所述将包括所述存储地址的交易数据保存至所述区块链网络的区块链中,包括:
16.针对每一交易附件,计算该交易附件的摘要信息;
17.向区块链网络发布目标交易请求,所述目标交易请求包括交易数据,所述交易数据包括交易附件的数量值、每一交易附件的摘要信息以及每一交易附件的存储地址。
18.可选地,还包括:
19.响应于接收到查询端发送的交易数据查询请求,确定待查询交易;
20.从所述区块链中查询所述待查询交易,得到所述待查询交易的交易数据;
21.基于所述待查询交易的交易数据中的存储地址,获取所述待查询交易的交易附件;
22.向所述查询端发送所述待查询交易的交易数据以及交易附件。
23.可选地,所述待查询交易的交易数据还包括交易附件的摘要信息,所述向所述查询端发送所述待查询交易的交易数据以及交易附件之前,还包括:
24.针对获取到的待查询交易的交易附件,计算该交易附件的目标摘要值;
25.确定所述目标摘要值与所述待查询交易的交易数据中的摘要值一致。
26.根据本公开实施例的第二方面,提供一种区块链数据处理装置,包括:
27.第一获取模块,被配置为获取交易数据保存请求,所述交易数据保存请求包括交易附件;
28.第一确定模块,被配置为从区块链网络中的多个数据保存节点中确定多个目标数据保存节点;
29.文件存储模块,被配置为通过所述目标数据保存节点对所述交易附件进行存储,得到所述交易附件的存储地址;
30.数据保存模块,被配置为将包括所述存储地址的交易数据保存至所述区块链网络的区块链中。
31.可选地,所述区块链网络中的多个数据保存节点共同构建为分布式文件系统,所述文件存储模块,包括:
32.第一发送子模块,被配置为向所述分布式文件系统发送交易附件保存请求,以使得所述分布式文件系统基于预设的节点选取规则,从所述多个数据保存节点中确定多个目标数据保存节点。
33.可选地,所述交易附件保存请求还包括用于描述交易附件备份次数的目标数量值,以使得所述分布式文件系统从所述多个数据保存节点中确定目标数量值个目标数据保存节点。
34.可选地,所述区块链网络中的多个数据保存节点共同构建发布文件保存智能合约,所述文件存储模块,包括:
35.节点确定子模块,被配置为基于所述文件保存智能合约中的预设节点选取规则,从所述多个数据保存节点中确定多个目标数据保存节点。
36.可选地,所述交易附件的数量为多个,所述数据保存模块,包括:
37.计算子模块,被配置为针对每一交易附件,计算该交易附件的摘要信息;
38.第二发送子模块,被配置为向区块链网络发布目标交易请求,所述目标交易请求包括交易数据,所述交易数据包括交易附件的数量值、每一交易附件的摘要信息以及每一交易附件的存储地址。
39.可选地,所述装置还包括:
40.第二确定模块,被配置为响应于接收到查询端发送的交易数据查询请求,确定待查询交易;
41.查询模块,被配置为从所述区块链中查询所述待查询交易,得到所述待查询交易
的交易数据;
42.第二获取模块,被配置为基于所述待查询交易的交易数据中的存储地址,获取所述待查询交易的交易附件;
43.发送模块,被配置为向所述查询端发送所述待查询交易的交易数据以及交易附件。
44.可选地,所述待查询交易的交易数据还包括交易附件的摘要信息,所述装置还包括:
45.计算模块,被配置为向所述查询端发送所述待查询交易的交易数据以及交易附件之前,针对获取到的待查询交易的交易附件,计算该交易附件的目标摘要值;
46.第三确定模块,被配置为确定所述目标摘要值与所述待查询交易的交易数据中的摘要值一致。
47.根据本公开实施例的第三方面,提供一种区块链数据处理装置,包括:
48.处理器;
49.用于存储处理器可执行指令的存储器;
50.其中,所述处理器被配置为:
51.获取交易数据保存请求,所述交易数据保存请求包括交易附件;
52.从区块链网络中的多个数据保存节点中确定多个目标数据保存节点;
53.通过所述目标数据保存节点对所述交易附件进行存储,得到所述交易附件的存储地址;
54.将包括所述存储地址的交易数据保存至所述区块链网络的区块链中。
55.根据本公开实施例的第四方面,提供一种计算机可读存储介质,其上存储有计算机程序指令,该程序指令被处理器执行时实现本公开第一方面中任一项所提供的区块链数据处理方法的步骤。
56.本公开的实施例提供的技术方案可以包括以下有益效果:
57.在获取到交易数据保存请求时,可以从区块链网络中的多个数据保存节点中确定多个目标数据保存节点。这样,可以通过所述目标数据保存节点对所述交易附件进行存储,得到所述交易附件的存储地址,并将包括所述存储地址的交易数据保存至所述区块链网络的区块链中。也就是说,上述技术方案在面对交易数据包含文件的场景时,可以将文件保存至多个目标数据保存节点中,并在区块链中写入文件的保存地址。通过这样的方式,上述技术方案能够满足交易过程中的文件信息的保存需求,并且保存的文件信息是完备的。
58.此外,由于上述技术方案是从区块链网络中的多个数据保存节点中选择一部分目标数据保存节点来存储所述交易附件,并在区块链中写入文件的保存地址。因此,相对于全局共识保存文件的方式,上述技术方案还能够提升文件的存储效率。
59.应当理解的是,以上的一般描述和后文的细节描述仅是示例性和解释性的,并不能限制本公开。
附图说明
60.此处的附图被并入说明书中并构成本说明书的一部分,示出了符合本公开的实施例,并与说明书一起用于解释本公开的原理。
61.图1是根据一示例性实施例示出的一种区块链数据处理方法的流程图。
62.图2是根据一示例性实施例示出的一种区块链数据处理方法的流程图。
63.图3是根据一示例性实施例示出的一种区块链数据处理方法的流程图。
64.图4是根据一示例性实施例示出的一种区块链数据处理方法的流程图。
65.图5是根据一示例性实施例示出的一种交易数据的组成示意图。
66.图6是根据一示例性实施例示出的一种区块链数据处理方法的流程图。
67.图7是根据一示例性实施例示出的一种区块链数据处理方法的流程图。
68.图8是根据一示例性实施例示出的一种区块链数据的查询流程图。
69.图9是根据一示例性实施例示出的一种区块链数据处理装置的框图。
70.图10是根据一示例性实施例示出的一种用于区块链数据处理的装置的框图。
具体实施方式
71.这里将详细地对示例性实施例进行说明,其示例表示在附图中。下面的描述涉及附图时,除非另有表示,不同附图中的相同数字表示相同或相似的要素。以下示例性实施例中所描述的实施方式并不代表与本公开相一致的所有实施方式。相反,它们仅是与如所附权利要求书中所详述的、本公开的一些方面相一致的装置和方法的例子。
72.在介绍本公开的区块链数据处理方法、装置及存储介质之前,首先对本公开的应用场景进行介绍。本公开所提供的各实施例可以应用于区块链网络中的数据处理场景,这里,区块链网络的类型可以是联盟链、公链等等。
73.以hyperledger fabric(超级账本)为例,在hyperledger fabric的数据节点中保存有区块数据、索引数据和数据库数据,其中区块数据和索引数据在每个数据节点上存在备份。也就是说,当网络中有100个数据节点时,该部分数据可以在区块链网络中产生100个备份,从而降低存储效率。因此,在hyperledger fabric中,通常不存储文件。
74.值得说明的是,相关场景中,交易可能会附带一些文件。例如在一些金融业务中,交易可能产生一些文件,如协议、契约、回执、发票等等,这些文件可以作为交易凭证的一部分。但是,由于存储效率的原因,这些文件难以在链上进行保存,即交易方需要自行保存这些文件。由于链上保存的不是完备的文件,因此当交易方遗失这些文件时,各个参与方也无法通过链上保存的文件的凭证获知完整的文件信息,最终对后续的交易和业务产生影响。
75.为此,本公开提供一种区块链数据处理方法,该方法例如可以应用于区块链网络中的节点。在具体实施时,所述节点可以是任何类型的静止或移动计算设备,如移动计算机、移动电话或其他类型的移动设备,或者诸如台式计算机的静止计算设备、服务器等等。
76.图1是根据一示例性实施例示出的一种区块链数据处理方法的流程图,如图1所示,所述方法包括以下步骤:
77.在步骤s11中,获取交易数据保存请求,所述交易数据保存请求包括交易附件。例如在一些场景中,交易附件例如可以是交易产生的协议、契约、回执、发票等等。
78.在步骤s12中,从区块链网络中的多个数据保存节点中确定多个目标数据保存节点。
79.例如在一种可能的实施方式中,所述区块链网络中的多个数据保存节点共同构建为分布式文件系统。在这种情况下,参照图2所示出的一种区块链数据处理方法的流程图,
所述从区块链网络中的多个数据保存节点中确定多个目标数据保存节点,包括:
80.s121,向分布式文件系统发送交易附件保存请求,以使得所述分布式文件系统基于预设的节点选取规则,从多个数据保存节点中确定多个目标数据保存节点。
81.示例地,区块链网络中可以包括节点1-100,其中节点1-80为数据保存节点。在一些实施场景中,多个数据保存节点可以共同构建为分布式文件系统,例如,数据保存节点20-70可以构建为分布式文件系统。
82.所述分布式服务系统例如还可以设置相关的调用接口。这样,节点可以通过所述调用接口向分布式文件系统发送交易附件保存请求。分布式文件系统在接收到所述交易附件保存请求之后,可以基于预设的节点选取规则,从数据保存节点20-70中确定多个目标数据保存节点。
83.其中,所述节点选取规则可以基于应用需求进行设置。例如在一些实施场景中,节点选取规则可以包括目标数据保存节点的数量值。例如,当目标数据保存节点的数量值为3时,分布式文件系统在接收到所述交易附件保存请求之后,可以从数据保存节点20-70中确定3个目标数据保存节点。并且,为了提升文件保存的效率,在确定目标数据保存节点的数量值时,可以在满足备份容灾需求的情况下取较小的值,如3、5等。也就是说,可以选择一部分的数据保存节点作为目标数据保存节点。
84.此外,所述节点选取规则例如还可以包括地理区域规则,以使得所选择的各个目标数据保存节点的物理存储区域为异地,进而起到异地容灾的效果。
85.上述实施例以分布式文件系统基于预设的节点选取规则为了对本公开的目标数据保存节点的选取过程进行了示例性说明,但在一些实施场景中,节点也可以参与至目标数据保存节点的选取过程中。例如在一种可能的实施方式中,节点向分布式文件系统发送的交易附件保存请求还包括用于描述交易附件备份次数的目标数量值(例如5个)。这样,所述分布式文件系统可以从所述多个数据保存节点中确定目标数量值个(例如5个)目标数据保存节点。
86.通过这样的方式,节点可以自定义交易附件的备份数量,从而可以满足不同的应用需求。
87.此外,在一种可能的实施方式中,所述区块链网络中的多个数据保存节点还可以共同构建发布文件保存智能合约。在这种情况下,参照图3所示出的一种区块链数据处理方法的流程图,所述从区块链网络中的多个数据保存节点中确定多个目标数据保存节点,包括:
88.s122,基于所述文件保存智能合约中的预设节点选取规则,从所述多个数据保存节点中确定多个目标数据保存节点。
89.示例地,区块链网络中可以包括节点1-100,其中节点1-80为数据保存节点。在一些实施场景中,多个数据保存节点可以共同构建发布文件保存智能合约。例如,数据保存节点30-70可以构建共同构建文件保存智能合约,并在区块链网络中部署所述文件保存智能合约。
90.其中,所述文件保存智能合约中例如还配置有节点选取规则。例如在一些实施场景中,节点选取规则可以包括目标数据保存节点的数量值。此外,所述节点选取规则例如还可以包括区域限制,以使得所选择的各个目标数据保存节点的物理存储区域为异地,进而
起到异地容灾的效果。
91.这样,节点在获取到交易数据保存请求之后,可以调用所述文件保存智能合约,从而获得所述智能合约反馈的多个目标数据保存节点的信息。所述节点还可通过所述目标数据保存节点对所述交易附件进行存储,得到所述交易附件的存储地址。
92.在一些实施场景中,所述文件保存智能合约也可以被配置为具备文件保存功能。在这种情况下,节点也可以通过调用所述文件保存智能合约的方式,对所述交易附件进行存储,从而得到所述交易附件的存储地址。
93.当然,所述文件保存智能合约中还可以配置多种交易附件的保存模式,例如在保存模式1中,交易附件可以被备份为3份(即选择3个目标数据保存节点),在保存模式2中,交易附件可以被备份为5份(即选择5个目标数据保存节点)。这样,节点在调用所述文件保存智能合约时,还可以通过不同的调用参数选择不同的保存模式,从而对交易附件的备份数量进行更改,进而满足不同的应用需求。
94.在步骤s13中,通过所述目标数据保存节点对所述交易附件进行存储,得到所述交易附件的存储地址。例如,在目标数据保存节点为节点30、节点35以及节点66的情况下,可以分别通过所述节点30、节点35以及节点66对所述交易附件进行存储,从而得到所述交易附件的保存地址。
95.在步骤s14中,将包括所述存储地址的交易数据保存至所述区块链网络的区块链中。
96.例如,节点可以在区块链网络广播包括所述交易数据的目标交易请求。这样,在区块链网络中的相关节点共识通过之后,所述交易数据可以被保存至所述区块链网络中的区块链中。
97.上述技术方案在面对交易数据包含文件的场景时,可以将文件保存至多个目标数据保存节点中,并在区块链中写入文件的保存地址。通过这样的方式,上述技术方案能够满足交易过程中的文件信息的保存需求,并且保存的文件信息是完备的。也就是说,即便交易方遗失了本地的交易附件,各个参与方仍能够通过区块链中的文件地址获取到原始的交易附件。
98.此外,由于上述技术方案是从区块链网络中的多个数据保存节点中选择一部分目标数据保存节点来存储所述交易附件,并在区块链中写入文件的保存地址。因此,相对于全局共识保存文件的方式,上述技术方案还能够提升文件的存储效率。
99.图4是根据一示例性实施例示出的一种区块链数据处理方法的流程图,如图4所示,所述方法包括以下步骤:
100.s41,获取交易数据保存请求,所述交易数据保存请求包括交易附件。其中,所述交易附件的数量可以为一个或多个。
101.s42,从区块链网络中的多个数据保存节点中确定多个目标数据保存节点。
102.s43,通过所述目标数据保存节点对所述交易附件进行存储,得到所述交易附件的存储地址。
103.s44,针对每一交易附件,计算该交易附件的摘要信息。示例地,在交易数据保存请求包括交易附件1-3的情况下,可以分别计算交易附件1、交易附件2以及交易附件3的摘要信息。
104.s45,向区块链网络发布目标交易请求,所述目标交易请求包括交易数据,所述交易数据包括交易附件的数量值、每一交易附件的摘要信息以及每一交易附件的存储地址。
105.示例地,目标交易请求中可以包括如下字段:
[0106][0107][0108]
参照图5所示出的一种交易数据的组成示意图,当交易附件的数量为6个时,交易数据可以包括交易附件1-6的存储地址,以及交易附件1-6的摘要信息。
[0109]
上述技术方案可以从区块链网络中的多个数据保存节点中选择一部分目标数据保存节点来存储交易附件,并在区块链中写入交易附件的保存地址。相对于全局共识保存文件的方式,上述技术方案能够提升文件的存储效率。同时,在交易数据中保存交易附件的摘要信息的方式,也有助于后续对交易附件的正确性校验,有助于提升交易附件的保存安全性。
[0110]
图6是根据一示例性实施例示出的一种区块链数据处理方法的流程图,参照图6,所述方法包括:
[0111]
目标节点接收客户端发送的交易数据保存请求,并基于客户端的公钥对所述交易数据保存请求中的客户端的签名进行验证。若客户端签名验证通过,则继续交易数据保存流程;若客户端签名验证失败,则返回错误代码给客户端,并终止入链流程。
[0112]
此外,在一些场景中,客户端可以作为代理端代理其他用户的交易数据保存请求。在这种情况下,所述目标节点在对所述客户端的验证通过之后,还可以验证交易数据保存请求中的原始交易用户的身份信息。当身份信息验证通过时,确定所述交易数据保存请求有效,此时继续数据保存流程;当身份信息验证失败时,则确定所述交易数据保存请求无效,此时返回错误代码给客户端,并终止入链流程。
[0113]
在交易数据保存请求有效的情况下,目标节点可以将交易数据保存请求中的每一个交易附件上传至分布式文件系统,得到所述交易附件的存储地址。所述目标节点还可以基于交易附件的文件名、摘要信息、存储地址生成attachments数据结构,并将attachments数据结构添加至交易数据中,生成交易请求。其中,分布式文件系统以及attachments数据结构请参照本公开的上述实施例说明,为了说明书的简洁,本公开对此不再赘述。
[0114]
参照图6,所述目标节点还可以通过向区块链网络中的共识节点发送所述交易请求。在共识节点共识完成之后,所述交易请求中所包括的交易数据可以被保存至区块链中。
[0115]
上述技术方案可以从区块链网络中的多个数据保存节点中选择一部分目标数据保存节点来存储交易数据以及交易附件,并在区块链中写入交易附件的保存地址。相对于全局共识保存文件的方式,上述技术方案能够提升文件的存储效率。同时,在交易数据中保存交易附件的摘要信息的方式,也有助于后续对交易附件的正确性校验,有助于提升交易附件的保存安全性。
[0116]
图7是根据一示例性实施例示出的一种区块链数据处理方法的流程图,参照图7,所述方法在图1的基础上还包括:
[0117]
s15,响应于接收到查询端发送的交易数据查询请求,确定待查询交易。例如,可以基于交易数据查询请求中的交易数据的时间戳、编号等信息确定带查询交易。
[0118]
s16,从所述区块链中查询所述待查询交易,得到所述待查询交易的交易数据。
[0119]
s17,基于所述待查询交易的交易数据中的存储地址,获取所述待查询交易的交易附件。例如,在所述存储地址表征交易附件存储在节点55的情况下,可以向节点55请求所述交易附件。
[0120]
s18,向所述查询端发送所述待查询交易的交易数据以及交易附件。
[0121]
在一种可能的实施方式中,所述待查询交易的交易数据还包括交易附件的摘要信息,所述向所述查询端发送所述待查询交易的交易数据以及交易附件之前,还包括:
[0122]
针对获取到的待查询交易的交易附件,计算该交易附件的目标摘要值;
[0123]
确定所述目标摘要值与所述待查询交易的交易数据中的摘要值一致。
[0124]
也就是说,针对获取到的交易附件,还可以通过计算摘要值的方式验证正确性。例如,当目标摘要值与所述待查询交易的交易数据中的摘要值不一致时,所述交易附件则可能被更改。通过这样的方式,能够提升节点反馈至查询端的数据的可信度。
[0125]
图8是根据一示例性实施例示出的一种区块链数据的查询流程图,如图8所示,数据查询流程可以包括:
[0126]
目标节点接收客户端的交易数据查询请求,并验证所述交易数据查询请求中的所述客户端的签名信息。当所述签名信息验证失败时,所述目标节点可以向所述客户端返回错误代码,并终止查询流程。当所述签名信息验证成功时,所述目标节点可以对所述交易数据查询请求的有效性进行验证。
[0127]
应当理解,客户端可以作为代理端代理其他用户的交易数据查询请求。在这种情况下,所述目标节点在对所述客户端的验证通过之后,还可以验证交易数据保存请求中的原始交易用户的身份信息。当身份信息验证失败时,目标节点可以确定所述交易数据查询请求无效,并返回错误代码给客户端,同时终止入链流程。当身份信息验证通过时,目标节点可以确定所述交易数据保存请求有效。在这种情况下,目标节点可以查询区块信息,得到查询数据。
[0128]
其中,若所述查询数据中包括attachments信息,则可以根据attachments信息查询分布式文件系统,从而确定每个交易附件。所述目标节点还可以基于attachments信息中的交易附件的摘要对每一交易附件进行验证,并在验证通过的情况下向客户端反馈查询结果。通过这样的方式,能够满足交易附件的查询需求。
[0129]
基于同一发明构思,本公开还提供一种区块链数据处理装置。图9是根据一示例性实施例示出的一种区块链数据处理装置的框图,装置900包括:
[0130]
第一获取模块901,被配置为获取交易数据保存请求,所述交易数据保存请求包括交易附件;
[0131]
第一确定模块902,被配置为从区块链网络中的多个数据保存节点中确定多个目标数据保存节点;
[0132]
文件存储模块903,被配置为通过所述目标数据保存节点对所述交易附件进行存储,得到所述交易附件的存储地址;
[0133]
数据保存模块904,被配置为将包括所述存储地址的交易数据保存至所述区块链网络的区块链中。
[0134]
上述技术方案中,在获取到交易数据保存请求时,可以从区块链网络中的多个数据保存节点中确定多个目标数据保存节点。这样,可以通过所述目标数据保存节点对所述交易附件进行存储,得到所述交易附件的存储地址,并将包括所述存储地址的交易数据保存至所述区块链网络的区块链中。也就是说,上述技术方案在面对交易数据包含文件的场景时,可以将文件保存至多个目标数据保存节点中,并在区块链中写入文件的保存地址。通过这样的方式,上述技术方案能够满足交易过程中的文件信息的保存需求。
[0135]
此外,由于上述技术方案是从区块链网络中的多个数据保存节点中选择一部分目标数据保存节点来存储所述交易附件,并在区块链中写入文件的保存地址。因此,相对于全局共识保存文件的方式,上述技术方案还能够提升文件的存储效率。
[0136]
可选地,所述区块链网络中的多个数据保存节点共同构建为分布式文件系统,所述文件存储模块903,包括:
[0137]
第一发送子模块,被配置为向所述分布式文件系统发送交易附件保存请求,以使得所述分布式文件系统基于预设的节点选取规则,从所述多个数据保存节点中确定多个目标数据保存节点。
[0138]
可选地,所述交易附件保存请求还包括用于描述交易附件备份次数的目标数量值,以使得所述分布式文件系统从所述多个数据保存节点中确定目标数量值个目标数据保存节点。
[0139]
可选地,所述区块链网络中的多个数据保存节点共同构建发布文件保存智能合约,所述文件存储模块903,包括:
[0140]
节点确定子模块,被配置为基于所述文件保存智能合约中的预设节点选取规则,从所述多个数据保存节点中确定多个目标数据保存节点。
[0141]
可选地,所述交易附件的数量为多个,所述数据保存模块904,包括:
[0142]
计算子模块,被配置为针对每一交易附件,计算该交易附件的摘要信息;
[0143]
第二发送子模块,被配置为向区块链网络发布目标交易数据保存请求,所述目标交易数据保存请求包括交易数据,所述交易数据包括交易附件的数量值、每一交易附件的摘要信息以及每一交易附件的存储地址。
[0144]
可选地,所述装置900还包括:
[0145]
第二确定模块,被配置为响应于接收到查询端发送的交易数据查询请求,确定待查询交易;
[0146]
查询模块,被配置为从所述区块链中查询所述待查询交易,得到所述待查询交易的交易数据;
[0147]
第二获取模块,被配置为基于所述待查询交易的交易数据中的存储地址,获取所述待查询交易的交易附件;
[0148]
发送模块,被配置为向所述查询端发送所述待查询交易的交易数据以及交易附件。
[0149]
可选地,所述待查询交易的交易数据还包括交易附件的摘要信息,所述装置900还包括:
[0150]
计算模块,被配置为向所述查询端发送所述待查询交易的交易数据以及交易附件之前,针对获取到的待查询交易的交易附件,计算该交易附件的目标摘要值;
[0151]
第三确定模块,被配置为确定所述目标摘要值与所述待查询交易的交易数据中的摘要值一致。
[0152]
关于上述实施例中的装置,其中各个模块执行操作的具体方式已经在有关该方法的实施例中进行了详细描述,此处将不做详细阐述说明。
[0153]
本公开还提供一种区块链数据处理装置,包括:
[0154]
处理器;
[0155]
用于存储处理器可执行指令的存储器;
[0156]
其中,所述处理器被配置为实现本公开所提供的区块链数据处理方法。
[0157]
本公开还提供一种计算机可读存储介质,其上存储有计算机程序指令,该程序指令被处理器执行时实现本公开所提供的区块链数据处理方法的步骤。
[0158]
图10是根据一示例性实施例示出的一种用于区块链数据处理的装置1000的框图,该装置例如可以被配置为区块链网络中的节点。其中,装置1000可以是移动电话,计算机,消息收发设备,平板设备,个人数字助理等。
[0159]
参照图10,装置1000可以包括以下一个或多个组件:处理组件1002,存储器1004,电力组件1006,多媒体组件1008,音频组件1010,输入/输出(i/o)的接口1012,传感器组件1014,以及通信组件1016。
[0160]
处理组件1002通常控制装置1000的整体操作,诸如与显示,电话呼叫,数据通信,相机操作和记录操作相关联的操作。处理组件1002可以包括一个或多个处理器1020来执行指令,以完成上述的区块链数据处理方法的全部或部分步骤。此外,处理组件1002可以包括一个或多个模块,便于处理组件1002和其他组件之间的交互。例如,处理组件1002可以包括多媒体模块,以方便多媒体组件1008和处理组件1002之间的交互。
[0161]
存储器1004被配置为存储各种类型的数据以支持在装置1000的操作。这些数据的示例包括用于在装置1000上操作的任何应用程序或方法的指令,联系人数据,电话簿数据,消息,图片,视频等。存储器1004可以由任何类型的易失性或非易失性存储设备或者它们的组合实现,如静态随机存取存储器(sram),电可擦除可编程只读存储器(eeprom),可擦除可编程只读存储器(eprom),可编程只读存储器(prom),只读存储器(rom),磁存储器,快闪存储器,磁盘或光盘。
[0162]
电力组件1006为装置1000的各种组件提供电力。电力组件1006可以包括电源管理系统,一个或多个电源,及其他与为装置1000生成、管理和分配电力相关联的组件。
[0163]
多媒体组件1008包括在所述装置1000和用户之间的提供一个输出接口的屏幕。在一些实施例中,屏幕可以包括液晶显示器(lcd)和触摸面板(tp)。如果屏幕包括触摸面板,屏幕可以被实现为触摸屏,以接收来自用户的输入信号。触摸面板包括一个或多个触摸传感器以感测触摸、滑动和触摸面板上的手势。所述触摸传感器可以不仅感测触摸或滑动动作的边界,而且还检测与所述触摸或滑动操作相关的持续时间和压力。在一些实施例中,多媒体组件1008包括一个前置摄像头和/或后置摄像头。当装置1000处于操作模式,如拍摄模式或视频模式时,前置摄像头和/或后置摄像头可以接收外部的多媒体数据。每个前置摄像头和后置摄像头可以是一个固定的光学透镜系统或具有焦距和光学变焦能力。
[0164]
音频组件1010被配置为输出和/或输入音频信号。例如,音频组件1010包括一个麦克风(mic),当装置1000处于操作模式,如呼叫模式、记录模式和语音识别模式时,麦克风被配置为接收外部音频信号。所接收的音频信号可以被进一步存储在存储器1004或经由通信组件1016发送。在一些实施例中,音频组件1010还包括一个扬声器,用于输出音频信号。
[0165]
i/o接口1012为处理组件1002和外围接口模块之间提供接口,上述外围接口模块可以是键盘,点击轮,按钮等。这些按钮可包括但不限于:主页按钮、音量按钮、启动按钮和锁定按钮。
[0166]
传感器组件1014包括一个或多个传感器,用于为装置1000提供各个方面的状态评估。例如,传感器组件1014可以检测到装置1000的打开/关闭状态,组件的相对定位,例如所述组件为装置1000的显示器和小键盘,传感器组件1014还可以检测装置1000或装置1000一个组件的位置改变,用户与装置1000接触的存在或不存在,装置1000方位或加速/减速和装置1000的温度变化。传感器组件1014可以包括接近传感器,被配置用来在没有任何的物理接触时检测附近物体的存在。传感器组件1014还可以包括光传感器,如cmos或ccd图像传感器,用于在成像应用中使用。在一些实施例中,该传感器组件1014还可以包括加速度传感器,陀螺仪传感器,磁传感器,压力传感器或温度传感器。
[0167]
通信组件1016被配置为便于装置1000和其他设备之间有线或无线方式的通信。装置1000可以接入基于通信标准的无线网络,如wifi,2g或3g,或它们的组合。在一个示例性实施例中,通信组件1016经由广播信道接收来自外部广播管理系统的广播信号或广播相关信息。在一个示例性实施例中,所述通信组件1016还包括近场通信(nfc)模块,以促进短程通信。例如,在nfc模块可基于射频识别(rfid)技术,红外数据协会(irda)技术,超宽带(uwb)技术,蓝牙(bt)技术和其他技术来实现。
[0168]
在示例性实施例中,装置1000可以被一个或多个应用专用集成电路(asic)、数字信号处理器(dsp)、数字信号处理设备(dspd)、可编程逻辑器件(pld)、现场可编程门阵列(fpga)、控制器、微控制器、微处理器或其他电子元件实现,用于执行上述区块链数据处理方法。
[0169]
在示例性实施例中,还提供了一种包括指令的非临时性计算机可读存储介质,例如包括指令的存储器1004,上述指令可由装置1000的处理器1020执行以完成上述区块链数据处理方法。例如,所述非临时性计算机可读存储介质可以是rom、随机存取存储器(ram)、cd-rom、磁带、软盘和光数据存储设备等。
[0170]
在另一示例性实施例中,还提供一种计算机程序产品,该计算机程序产品包含能够由可编程的装置执行的计算机程序,该计算机程序具有当由该可编程的装置执行时用于
执行上述的区块链数据处理方法的代码部分。
[0171]
本领域技术人员在考虑说明书及实践本公开后,将容易想到本公开的其它实施方案。本技术旨在涵盖本公开的任何变型、用途或者适应性变化,这些变型、用途或者适应性变化遵循本公开的一般性原理并包括本公开未公开的本技术领域中的公知常识或惯用技术手段。说明书和实施例仅被视为示例性的,本公开的真正范围和精神由下面的权利要求指出。
[0172]
应当理解的是,本公开并不局限于上面已经描述并在附图中示出的精确结构,并且可以在不脱离其范围进行各种修改和改变。本公开的范围仅由所附的权利要求来限制。