一种残膜回收机防缠绕挑膜装置的制 一种秧草收获机用电力驱动行走机构

数据写入方法和装置、计算机可读存储介质、电子设备与流程

2022-06-05 02:44:14 来源:中国专利 TAG:


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.图1是本公开实施例涉及的一个示例性的跨链体系架构图;图2是本公开一示例性实施例提供的数据写入方法的流程示意图;图3是本公开图2所示的实施例中步骤202的一流程示意图;图4是本公开图2所示的实施例中步骤204的一流程示意图;图5是本公开图2所示的实施例中步骤206的一流程示意图;图6是本公开图2所示的实施例中步骤210的一流程示意图;图7是本公开一示例性实施例中跨链互操作的交互示意图;图8是本公开一示例性实施例提供的数据写入装置的结构示意图;图9是本公开一示例性实施例提供的电子设备的结构图。
具体实施方式
26.下面,将参考附图详细地描述根据本公开的示例实施例。显然,所描述的实施例仅仅是本公开的一部分实施例,而不是本公开的全部实施例,应理解,本公开不受这里描述的示例实施例的限制。
27.应注意到:除非另外具体说明,否则在这些实施例中阐述的部件和步骤的相对布置、数字表达式和数值不限制本公开的范围。
28.本领域技术人员可以理解,本公开实施例中的“第一”、“第二”等术语仅用于区别不同步骤、设备或模块等,既不代表任何特定技术含义,也不表示它们之间的必然逻辑顺序。
29.还应理解,在本公开实施例中,“多个”可以指两个或两个以上,“至少一个”可以指一个、两个或两个以上。
30.还应理解,对于本公开实施例中提及的任一部件、数据或结构,在没有明确限定或者在前后文给出相反启示的情况下,一般可以理解为一个或多个。
31.另外,本公开中术语“和/或”,仅仅是一种描述关联对象的关联关系,表示可以存在三种关系,例如,a和/或b,可以表示:单独存在a,同时存在a和b,单独存在b这三种情况。另外,本公开中字符“/”,一般表示前后关联对象是一种“或”的关系。本公开中所指数据可以包括文本、图像、视频等非结构化数据,也可以是结构化数据。
32.还应理解,本公开对各个实施例的描述着重强调各个实施例之间的不同之处,其相同或相似之处可以相互参考,为了简洁,不再一一赘述。
33.同时,应当明白,为了便于描述,附图中所示出的各个部分的尺寸并不是按照实际的比例关系绘制的。
34.以下对至少一个示例性实施例的描述实际上仅仅是说明性的,决不作为对本公开及其应用或使用的任何限制。
35.对于相关领域普通技术人员已知的技术、方法和设备可能不作详细讨论,但在适
当情况下,所述技术、方法和设备应当被视为说明书的一部分。
36.应注意到:相似的标号和字母在下面的附图中表示类似项,因此,一旦某一项在一个附图中被定义,则在随后的附图中不需要对其进行进一步讨论。
37.本公开实施例可以应用于终端设备、计算机系统、服务器等电子设备,其可与众多其它通用或专用计算系统环境或配置一起操作。适于与终端设备、计算机系统、服务器等电子设备一起使用的众所周知的终端设备、计算系统、环境和/或配置的例子包括但不限于:个人计算机系统、服务器计算机系统、瘦客户机、厚客户机、手持或膝上设备、基于微处理器的系统、机顶盒、可编程消费电子产品、网络个人电脑、小型计算机系统、大型计算机系统和包括上述任何系统的分布式云计算技术环境,等等。
38.终端设备、计算机系统、服务器等电子设备可以在由计算机系统执行的计算机系统可执行指令(诸如程序模块)的一般语境下描述。通常,程序模块可以包括例程、程序、目标程序、组件、逻辑、数据结构等等,它们执行特定的任务或者实现特定的抽象数据类型。计算机系统/服务器可以在分布式云计算环境中实施,分布式云计算环境中,任务是由通过通信网络链接的远程处理设备执行的。在分布式云计算环境中,程序模块可以位于包括存储设备的本地或远程计算系统存储介质上。
39.示例性架构如图1所示,为本公开实施例涉及的一个示例性的跨链体系架构图,包括一条主链、一条或多条从链,主链上包括多个超级节点、服务节点和一个监管节点,从链可以为基础从链、区域性从链、行业性从链等,每条从链上包括一个骨干节点和多个服务节点、共识节点,本公开中涉及的第一区块链、第二区块链可以为从链。
40.其中,主链为整个链群提供公共服务,为各个从链提供跨链交互平台及规范。主链的监管节点负责对整个链群用户和节点的数据、行为进行合法合规监管并对违法违规行为进行处置,如关停服务、限制权限、不可信用户标记等,此外,监管节点对主链的超级节点和从链的骨干节点等具有管理权限的节点进行资质审核以及可信认证。主链的超级节点负责执行主链共识、跨链网关、资质审核、链群管理等功能,获取外部数据经过核验后对外提供可信数据服务。具体的,超级节点设置有验证引擎、执行引擎和交易路由,骨干节点包括事务管理模块、应用链管理模块、跨链网关、应用链适配器,从链上包括有跨链管理合约模块、事务管理模块、跨链网关、从链适配器。主链上的超级节点的验证引擎内注册有不同架构区块链的验证规则;想要加入从链的节点需要向该从链的服务节点发起注册请求,再由该服务节点通过骨干节点向主链节点注册。
41.示例性方法图2是本公开一示例性实施例提供的数据写入方法的流程示意图。本实施例可应用在电子设备上;如图2所示,包括如下步骤:步骤202,在第一区块链中预执行从客户端接收的第一交易数据,得到第一生效状态信息。
42.本实施例中客户端可以为在第一区块链中注册的用户使用的客户端,其中的用户可以是企业、个人等用户;本实施例中第一生效状态信息表示的第一生效状态,可以为预生效状态,预生效状态区别于生效状态,是生效之前的预备状态,只有在第一交易数据通过第二区块链的验证后,第一交易数据的状态才会由预生效变更为生效。
43.步骤204,基于第一区块链中的预设节点将第一交易数据和第一交易数据对应的调用信息发送给第二区块链。
44.可选地,交易数据可以包括交易所需要的信息,这些信息可以以统一的标识来表示该交易,例如:交易数据包括交易1、买方用户、卖方用户、转账金额等;本实施例中第一区块链可以包括骨干节点和至少一个服务节点,预设节点可以为第一区块链中的骨干节点,第一区块链中的服务节点通过骨干节点将第一交易数据和调用信息通过主链发送到第二区块链,通过该预设节点实现第一区块链和第二区块链之间的信息交互。
45.步骤206,基于调用信息,在第二区块链中执行与第一交易数据相关联的第二交易数据,得到第二交易数据对应的第二生效状态信息。
46.在一些实施例中,第二交易数据和第一交易数据可以具有一定的相关关系,即二者有一定的关联,本技术对具体的关联方式或关联内容不做限制。
47.步骤208,通过预设节点获取第二交易数据对应的验证信息和第二生效状态信息。
48.可选地,第二生效状态信息表示的第二生效状态表示第二区块链中的第二交易数据执行成功;在第二交易数据执行成功后,第二区块链的调用合约将第二区块链的第二交易数据的执行状态(第二生效状态信息)以及验证信息,发送给第一区块链的预设节点,该预设节点再将第二区块链的第二交易数据的执行状态(第二生效状态信息)以及验证信息发送至第一区块链的执行合约。
49.步骤210,根据第二生效状态信息和验证信息对第一交易数据进行执行,将得到的执行结果反馈给客户端。
50.本实施例中,只有在第二交易数据执行成功后,第一区块链才会对第一交易数据开始执行。可选地,第一区块链和第二区块链可以是同构链、也可以是异构链,在跨链时需要在主链注册登记、分配跨链id等。
51.本公开上述实施例提供的一种数据写入方法,在第一区块链中预执行从客户端接收的第一交易数据,得到第一生效状态信息;基于所述第一区块链中的预设节点将所述第一交易数据和所述第一交易数据对应的调用信息发送给第二区块链;基于所述调用信息,在所述第二区块链中执行与所述第一交易数据相关联的第二交易数据,得到所述第二交易数据对应的第二生效状态信息;通过所述预设节点获取所述第二交易数据对应的验证信息和所述第二生效状态信息;根据所述第二生效状态信息和所述验证信息对所述第一交易数据进行执行,将得到的执行结果反馈给所述客户端;本实施例通过第二区块链对用户提交的交易的第二交易数据进行验证和生效,提高了跨链交易的安全性。
52.如图3所示,在上述图2所示实施例的基础上,步骤202可包括如下步骤:步骤2021,通过第一区块链接收客户端发送的第一交易数据和与第一交易数据相关联的第二交易数据。
53.步骤2022,通过智能合约对第一交易数据进行预执行,使第一交易数据对应的状态信息更新为第一生效状态信息。
54.第一区块链中的执行合约执行第一交易数据相关的智能合约代码,生成第一交易数据指定的状态数据,对第一交易数据的交易状态执行为预生效状态(第一声学状态),将第一交易数据打包到区块里,和第一生效状态信息一起在区块中存储。
55.步骤2023,得到第一生效状态信息及第一生效状态信息对应的第一时间戳。
56.本实施例中,记录得到第一生效状态信息的时刻为第一时间戳,通过第一时间戳保证了在设定的时间周期内跨链操作是有效的,而对超过时间周期的跨链操作可判定为违法操作,拒绝执行,进一步提升了跨链操作的安全性。
57.如图4所示,在上述图2所示实施例的基础上,步骤204可包括如下步骤:步骤2041,通过预设节点获取第一交易数据、调用信息、第二交易数据和第一时间戳。
58.步骤2042,对第一交易数据、调用信息、第二交易数据执行加密处理,得到加密数据。
59.可选地,可通过现有技术中任一加密方法对第一交易数据和调用信息执行加密处理,例如,密钥加密、数据格式转换加密等,通过加密处理进一步提升了跨链操作时,数据的安全性。
60.步骤2043,对加密数据和第一时间戳执行封装处理,将得到的封装数据发送给第二区块链。
61.本实施例中,预设节点可以为第一区块链中的骨干节点,该骨干节点通过跨链协议将跨链提案提交到主链的跨链合约上,主链的跨链合约进行校验;第二区块链的跨链网关监听到需要转发到第二区块链的第一交易数据和调用信息,并反馈数据提交到主链的跨链合约中更新跨链交易状态,表示第二区块链已经收到第一交易数据和调用信息;本实施例中在加密数据的基础上还封装了第一时间戳,保证了第二区块链在接收到加密数据的同时接收到第一时间戳,保证了跨链操作的时效性。
62.可选地,步骤2043可以包括:通过跨链协议将跨链请求发送给主链中的跨链合约中;通过跨链合约对跨链请求进行校验;将通过校验的跨链请求对应的封装数据发送到第二区块链中。
63.本实施例中,由于第一区块链和第二区块链都是主链的从链,因此,在执行跨链操作时,通过主链中的跨链合约对跨链请求进行校验,确定该跨链请求是否合法,例如,确定接收跨链请求的时刻与第一时间戳之间的时间差是否符合设定周期(具体时长根据应用场景进行设置),当在设定周期内时,确定跨链请求合法,否则,确定跨链请求不合法,对于不合法的跨链请求向第一区块链反馈校验失败信息,并不向第二区块链发送任何信息;只有当校验通过时,将封装数据发送到第二区块链中。
64.如图5所示,在上述图2所示实施例的基础上,步骤206可包括如下步骤:步骤2061,基于调用信息确定第二区块链中的调用合约。
65.步骤2062,基于调用合约执行第二交易数据,使第二交易数据对应的状态信息更新为第二生效状态信息。
66.步骤2063,得到第二生效状态信息及第二生效状态信息对应的第二时间戳。
67.本实施例中,在第二区块链中,可通过预设解密方法对加密数据进行解密,获得调用信息,并基于该调用信息获得第二区块链中预存的调用合约,基于调用合约根据调用信息和第一交易数据,从第二区块链中预存的多个交易数据中确定与第一交易数据对应的交易数据作为第二交易数据,通过在第二区块链执行第二交易数据实现对第一交易数据的验证。
68.在一些可选的实施例中,步骤208可以包括:确定第二时间戳与第一时间戳之间的时间差值是否小于预设时间差值;响应于时间差值小于预设时间差值,通过预设节点获取第二交易数据对应的验证信息和第二生效状态信息。
69.本实施例中,为了保证跨链验证的时效性,在第二交易数据执行后,还获取第二生效状态信息对应的第二时间戳,以第二时间戳和第一时间戳之间的时间差值来确定第二区块链对第一交易数据的验证是否及时,当第二交易数据的执行超过预设时间差值时,说明第二区块链未及时进行跨链验证,为保证跨链数据的安全性,将不再发送第二交易数据对应的验证数据和第二生效状态信息到第一区块链中,避免了跨链验证的失误,提升了交易数据的安全性。
70.如图6所示,在上述图2所示实施例的基础上,步骤210可包括如下步骤:步骤2101,通过执行合约对第二生效状态信息和验证信息执行验证,当验证通过,执行步骤2102;否则,执行步骤2104。
71.步骤2102,通过执行合约对第一交易数据进行执行,使第一交易数据对应的状态信息更新为第三生效状态信息;执行步骤2103。
72.步骤2103,将第三生效状态信息作为执行结果反馈给客户端。
73.步骤2104,将验证不通过信息作为执行结果反馈给客户端。
74.在一种实施方式中,第二区块链的调用合约通过第二区块链的骨干节点将第二区块链的第二交易数据的执行状态(第二生效状态信息)以及验证信息发送至主链上,主链对其进行验证后提交,第一区块链的骨干节点监听到需要发送给自己的第二区块链的第二交易数据的执行状态(第二生效状态信息)以及验证信息后,将第二区块链的第二交易数据的执行状态(第二生效状态信息)以及验证信息存储,并反馈主链表示已收到第二区块链的第二交易数据的执行状态(第二生效状态信息)以及验证信息的消息,由第一区块链的执行合约对第二区块链的第二交易数据的执行状态(第二生效状态信息)以及验证信息进行验证。
75.如果第一区块链的执行合约在其规定时间内(可通过接收第二生效状态信息的时刻与第一时间戳之间的差值确定是否在规定时间内)收到了第二区块链的第二交易数据的执行状态(第二生效状态信息)以及验证信息,则对该信息进行验证,并在验证通过后提交最终的生效状态,表示第一交易数据最终生效。
76.如果超过第一区块链的执行合约的规定时间,那么,第一区块链的执行合约则验证信息不通过、或者无验证信息返回,执行状态回滚;如果第一区块链的执行合约在其规定时间内没有收到第二区块链的第二交易数据的执行状态(第二生效状态信息)以及验证信息,则第一区块链的执行合约执行状态回滚,将第一交易数据的预生效状态改为验证不通过,或者不返回验证信息(即不将预生效状态改为生效状态)。
77.第一区块链的执行合约将第一交易数据验证通过的生效状态、或者第一交易数据验证不通过的结果反馈给客户端。
78.在交易共识和验证、跨链操作的过程中,主链的监管节点对所有区块链的节点和数据进行监管,每个从链的骨干节点监管对应从链的区块链节点和数据,由主链的监管节点授权审核。
79.图7是本公开一示例性实施例中跨链互操作的交互示意图。
80.如图7所示,跨链互操作的非事务写入过程可以包括:步骤1、用户通过客户端向第一区块链发送第一交易数据;步骤2、第一区块链中的执行合约对第一交易数据预生效(对应本技术上述实施例总的预执行);步骤3、预设节点将第一交易数据和调用信息发送至第二区块链的调用合约;步骤4、第二区块链的调用合约生效第二交易数据;步骤5、第二区块链的调用合约将第二交易数据信息通过预设节点发送回第一区块链的执行合约;步骤6、第一区块链执行合约验证信息通过后,执行第一交易数据;步骤7、第一区块链的执行合约向客户端返回执行结果。
81.下面再以一具体可选实例进行详细说明。
82.假设用户a为区块链a(对应于上述实施例中第一区块链)上的注册用户,用户a通过商品买卖系统提交订单,并支付订单,卖家b为区块链b(对应于上述实施例中第二区块链)上的注册用户。
83.用户a向其所在的区块链a发送购买商品的订单交易(对应于上述实施例中第一交易数据)以及向卖家付款的交易;区块链a的执行合约将购买商品的订单交易进行预生效,并将订单交易和付款调用信息(对应于上述实施例中第一交易数据的调用信息)通过预设节点发送至主链,主链上的超级节点对订单交易和付款调用信息进行验证后,将订单交易和付款调用信息发送至区块链b;区块链b的服务节点对付款调用信息进行验证后,调用合约根据付款调用信息拉取付款交易(对应于上述实施例中第二交易数据),并进行区块打包;其他服务节点对区块进行验证,验证通过后将区块写入账本,将付款交易生效;区块链b的服务节点通过预设节点将付款交易的状态发送至区块链a;区块链a接收到付款交易的成功状态后,将订单交易最终生效;区块链a反馈用户下单已成功的提示消息。
84.本技术实施例中用户在一条区块链上提交交易及其第二交易数据,该区块链先将该交易预生效,在另一条区块链对第二交易数据进行验证和生效后,再对该交易进行最终生效,提高了跨链交易的安全性。
85.本公开实施例提供的任一种数据写入方法可以由任意适当的具有数据处理能力的设备执行,包括但不限于:终端设备和服务器等。或者,本公开实施例提供的任一种数据写入方法可以由处理器执行,如处理器通过调用存储器存储的相应指令来执行本公开实施例提及的任一种数据写入方法。下文不再赘述。
86.示例性装置图8是本公开一示例性实施例提供的数据写入装置的结构示意图。本实施例可应用在第一区块链上,如图8所示,本实施例提供的装置包括:预执行模块81,用于在第一区块链中预执行从客户端接收的第一交易数据,得到第一生效状态信息。
87.信息发送模块82,用于基于第一区块链中的预设节点将第一交易数据和第一交易数据对应的调用信息发送给第二区块链。
88.第二交易执行模块83,用于基于调用信息,在第二区块链中执行与第一交易数据相关联的第二交易数据,得到第二交易数据对应的第二生效状态信息。
89.信息获取模块84,用于通过预设节点获取第二交易数据对应的验证信息和第二生效状态信息。
90.交易执行模块85,用于根据第二生效状态信息和验证信息对第一交易数据进行执行,将得到的执行结果反馈给客户端。
91.本公开上述实施例提供的一种数据写入装置,预执行从客户端接收的第一交易数据,得到第一生效状态信息;基于预设节点将所述第一交易数据和所述第一交易数据对应的调用信息发送给第二区块链;基于所述调用信息在所述第二区块链中执行与所述第一交易数据相关联的第二交易数据,得到所述第二交易数据对应的第二生效状态信息;通过所述预设节点获取所述第二交易数据对应的验证信息和所述第二生效状态信息;根据所述第二生效状态信息和所述验证信息对所述第一交易数据进行执行,将得到的执行结果反馈给所述客户端;本实施例通过第二区块链对用户提交的交易的第二交易数据进行验证和生效,提高了跨链交易的安全性。
92.可选地,预执行模块,具体用于通过第一区块链接收客户端发送的第一交易数据和与第一交易数据相关联的第二交易数据;通过智能合约对第一交易数据进行预执行,使第一交易数据对应的状态信息更新为第一生效状态信息;得到第一生效状态信息及第一生效状态信息对应的第一时间戳。
93.可选地,信息发送模块,具体用于通过预设节点获取第一交易数据、调用信息、第二交易数据和第一时间戳;对第一交易数据、调用信息和第二交易数据执行加密处理,得到加密数据;对加密数据和第一时间戳执行封装处理,将得到的封装数据发送给第二区块链。
94.可选地,信息发送模块在将得到的封装数据发送给第二区块链时,用于通过跨链协议将跨链请求发送给主链中的跨链合约中;通过跨链合约对跨链请求进行校验;将通过校验的跨链请求对应的封装数据发送到第二区块链中。
95.可选地,第二交易执行模块,包括:合约调用单元,用于基于调用信息确定第二区块链中的调用合约;状态更新单元,用于基于调用合约执行第二交易数据,使第二交易数据对应的状态信息更新为第二生效状态信息;生效信息单元,用于得到第二生效状态信息及第二生效状态信息对应的第二时间戳。
96.可选地,状态更新单元,具体用于确定第二时间戳与第一时间戳之间的时间差值是否小于预设时间差值;响应于时间差值小于预设时间差值,通过预设节点获取第二交易数据对应的验证信息和第二生效状态信息。
97.可选地,交易执行模块,具体用于通过执行合约对第二生效状态信息和验证信息执行验证;响应于验证通过,通过执行合约对第一交易数据进行执行,使第一交易数据对应的状态信息更新为第三生效状态信息;将第三生效状态信息作为执行结果反馈给客户端。
98.可选地,交易执行模块,还用于响应于验证不通过,将验证不通过信息作为执行结
果反馈给客户端。
99.示例性电子设备下面,参考图9来描述根据本公开实施例的电子设备。该电子设备可以是第一设备和第二设备中的任一个或两者、或与它们独立的单机设备,该单机设备可以与第一设备和第二设备进行通信,以从它们接收所采集到的输入信号。
100.图9图示了根据本公开实施例的电子设备的框图。
101.如图9所示,电子设备90包括一个或多个处理器91和存储器92。
102.处理器91可以是中央处理单元(cpu)或者具有数据处理能力和/或指令执行能力的其他形式的处理单元,并且可以控制电子设备90中的其他组件以执行期望的功能。
103.存储器92可以包括一个或多个计算机程序产品,所述计算机程序产品可以包括各种形式的计算机可读存储介质,例如易失性存储器和/或非易失性存储器。所述易失性存储器例如可以包括随机存取存储器(ram)和/或高速缓冲存储器(cache)等。所述非易失性存储器例如可以包括只读存储器(rom)、硬盘、闪存等。在所述计算机可读存储介质上可以存储一个或多个计算机程序指令,处理器91可以运行所述程序指令,以实现上文所述的本公开的各个实施例的数据写入方法以及/或者其他期望的功能。在所述计算机可读存储介质中还可以存储诸如输入信号、信号分量、噪声分量等各种内容。
104.在一个示例中,电子设备90还可以包括:输入装置93和输出装置94,这些组件通过总线系统和/或其他形式的连接机构(未示出)互连。
105.例如,在该电子设备是第一设备或第二设备时,该输入装置93可以是上述的麦克风或麦克风阵列,用于捕捉声源的输入信号。在该电子设备是单机设备时,该输入装置93可以是通信网络连接器,用于从第一设备和第二设备接收所采集的输入信号。
106.此外,该输入装置93还可以包括例如键盘、鼠标等等。
107.该输出装置94可以向外部输出各种信息,包括确定出的距离信息、方向信息等。该输出装置94可以包括例如显示器、扬声器、打印机、以及通信网络及其所连接的远程输出设备等等。
108.当然,为了简化,图9中仅示出了该电子设备90中与本公开有关的组件中的一些,省略了诸如总线、输入/输出接口等等的组件。除此之外,根据具体应用情况,电子设备90还可以包括任何其他适当的组件。
109.示例性计算机程序产品和计算机可读存储介质除了上述方法和设备以外,本公开的实施例还可以是计算机程序产品,其包括计算机程序指令,所述计算机程序指令在被处理器运行时使得所述处理器执行本说明书上述“示例性方法”部分中描述的根据本公开各种实施例的数据写入方法中的步骤。
110.所述计算机程序产品可以以一种或多种程序设计语言的任意组合来编写用于执行本公开实施例操作的程序代码,所述程序设计语言包括面向对象的程序设计语言,诸如java、c 等,还包括常规的过程式程序设计语言,诸如“c”语言或类似的程序设计语言。程序代码可以完全地在用户计算设备上执行、部分地在用户设备上执行、作为一个独立的软件包执行、部分在用户计算设备上部分在远程计算设备上执行、或者完全在远程计算设备或服务器上执行。
111.此外,本公开的实施例还可以是计算机可读存储介质,其上存储有计算机程序指
令,所述计算机程序指令在被处理器运行时使得所述处理器执行本说明书上述“示例性方法”部分中描述的根据本公开各种实施例的数据写入方法中的步骤。
112.所述计算机可读存储介质可以采用一个或多个可读介质的任意组合。可读介质可以是可读信号介质或者可读存储介质。可读存储介质例如可以包括但不限于电、磁、光、电磁、红外线、或半导体的系统、装置或器件,或者任意以上的组合。可读存储介质的更具体的例子(非穷举的列表)包括:具有一个或多个导线的电连接、便携式盘、硬盘、随机存取存储器(ram)、只读存储器(rom)、可擦式可编程只读存储器(eprom或闪存)、光纤、便携式紧凑盘只读存储器(cd-rom)、光存储器件、磁存储器件、或者上述的任意合适的组合。
113.以上结合具体实施例描述了本公开的基本原理,但是,需要指出的是,在本公开中提及的优点、优势、效果等仅是示例而非限制,不能认为这些优点、优势、效果等是本公开的各个实施例必须具备的。另外,上述公开的具体细节仅是为了示例的作用和便于理解的作用,而非限制,上述细节并不限制本公开为必须采用上述具体的细节来实现。
114.本说明书中各个实施例均采用递进的方式描述,每个实施例重点说明的都是与其它实施例的不同之处,各个实施例之间相同或相似的部分相互参见即可。对于系统实施例而言,由于其与方法实施例基本对应,所以描述的比较简单,相关之处参见方法实施例的部分说明即可。
115.本公开中涉及的器件、装置、设备、系统的方框图仅作为例示性的例子并且不意图要求或暗示必须按照方框图示出的方式进行连接、布置、配置。如本领域技术人员将认识到的,可以按任意方式连接、布置、配置这些器件、装置、设备、系统。诸如“包括”、“包含”、“具有”等等的词语是开放性词汇,指“包括但不限于”,且可与其互换使用。这里所使用的词汇“或”和“和”指词汇“和/或”,且可与其互换使用,除非上下文明确指示不是如此。这里所使用的词汇“诸如”指词组“诸如但不限于”,且可与其互换使用。
116.可能以许多方式来实现本公开的方法和装置。例如,可通过软件、硬件、固件或者软件、硬件、固件的任何组合来实现本公开的方法和装置。用于所述方法的步骤的上述顺序仅是为了进行说明,本公开的方法的步骤不限于以上具体描述的顺序,除非以其它方式特别说明。此外,在一些实施例中,还可将本公开实施为记录在记录介质中的程序,这些程序包括用于实现根据本公开的方法的机器可读指令。因而,本公开还覆盖存储用于执行根据本公开的方法的程序的记录介质。
117.还需要指出的是,在本公开的装置、设备和方法中,各部件或各步骤是可以分解和/或重新组合的。这些分解和/或重新组合应视为本公开的等效方案。
118.提供所公开的方面的以上描述以使本领域的任何技术人员能够做出或者使用本公开。对这些方面的各种修改对于本领域技术人员而言是非常显而易见的,并且在此定义的一般原理可以应用于其他方面而不脱离本公开的范围。因此,本公开不意图被限制到在此示出的方面,而是按照与在此公开的原理和新颖的特征一致的最宽范围。
119.为了例示和描述的目的已经给出了以上描述。此外,此描述不意图将本公开的实施例限制到在此公开的形式。尽管以上已经讨论了多个示例方面和实施例,但是本领域技术人员将认识到其某些变型、修改、改变、添加和子组合。
再多了解一些

本文用于企业家、创业者技术爱好者查询,结果仅供参考。

发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表

相关文献