一种区块链公链网络结构的获取方法、装置、电子设备与流程

文档序号:31879879发布日期:2022-10-21 22:54阅读:131来源:国知局
一种区块链公链网络结构的获取方法、装置、电子设备与流程

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.判断所述响应状态码是否为200;
34.若是,接收所述目标节点的所述第二响应信息。
35.在上述实现过程中,根据目标节点的响应状态码的数值判断是否接收第二响应信息,可以保证得到的第二响应信息的准确性,提高接收效率。
36.进一步地,所述根据所述第二响应信息获得所述节点间的通讯关系信息的步骤,包括:
37.提取所述第二响应信息中的ip地址和端口信息;
38.根据所述ip地址和所述端口信息获得所述节点间的通讯关系信息。
39.在上述实现过程中,根据ip地址和端口信息获得节点间的通讯关系信息,使得到的通讯关系信息更加准确,有助于快速地寻找节点的端口信息。
40.第二方面,本技术实施例还提供了一种区块链公链网络结构的获取装置,所述装置包括:
41.获取模块,用于获取区块链公链的接口文档信息;
42.解析模块,用于对所述接口文档信息进行解析,得到节点常规信息和节点列表;
43.构建模块,用于根据所述节点常规信息构建第一探测包;还用于根据所述第一探
测包和所述节点列表构建第二探测包;
44.连接模块,用于根据所述第二探测包获得节点间的通讯关系信息;
45.生成模块,用于根据所述通讯关系信息生成区块链公链网络结构。
46.在上述实现过程中,通过构建探测包,主动向目标节点进行探测获得节点间的通讯关系信息,从而建立区块链公链各个节点间的连接关系,生成网络结构,可以提高生成网络结构的效率的同时,不会对区块链的安全造成影响。
47.第三方面,本技术实施例提供的一种电子设备,包括:存储器、处理器以及存储在所述存储器中并可在所述处理器上运行的计算机程序,所述处理器执行所述计算机程序时实现如第一方面任一项所述的方法的步骤。
48.第四方面,本技术实施例提供的一种计算机可读存储介质,所述存储介质上存储有指令,当所述指令在计算机上运行时,使得所述计算机执行如第一方面任一项所述的方法。
49.第五方面,本技术实施例提供的一种计算机程序产品,所述计算机程序产品在计算机上运行时,使得计算机执行如第一方面任一项所述的方法。
50.本公开的其他特征和优点将在随后的说明书中阐述,或者,部分特征和优点可以从说明书推知或毫无疑义地确定,或者通过实施本公开的上述技术即可得知。
51.并可依照说明书的内容予以实施,以下以本技术的较佳实施例并配合附图详细说明如后。
附图说明
52.为了更清楚地说明本技术实施例的技术方案,下面将对本技术实施例中所需要使用的附图作简单地介绍,应当理解,以下附图仅示出了本技术的某些实施例,因此不应被看作是对范围的限定,对于本领域普通技术人员来讲,在不付出创造性劳动的前提下,还可以根据这些附图获得其他相关的附图。
53.图1为本技术实施例提供的区块链公链网络结构的获取方法的流程示意图;
54.图2为本技术实施例提供的区块链公链网络结构的获取装置的结构组成示意图;
55.图3为本技术实施例提供的电子设备的结构组成示意图。
具体实施方式
56.下面将结合本技术实施例中的附图,对本技术实施例中的技术方案进行描述。
57.应注意到:相似的标号和字母在下面的附图中表示类似项,因此,一旦某一项在一个附图中被定义,则在随后的附图中不需要对其进行进一步定义和解释。同时,在本技术的描述中,术语“第一”、“第二”等仅用于区分描述,而不能理解为指示或暗示相对重要性。
58.下面结合附图和实施例,对本技术的具体实施方式作进一步详细描述。以下实施例用于说明本技术,但不用来限制本技术的范围。
59.实施例一
60.图1是本技术实施例提供的区块链公链网络结构的获取方法的流程示意图,如图1所示,该方法包括:
61.s1,获取区块链公链的接口文档信息;
62.s2,对接口文档信息进行解析,得到节点常规信息和节点列表;
63.s3,根据节点常规信息构建第一探测包;
64.s4,根据第一探测包和节点列表构建第二探测包;
65.s5,根据第二探测包获得节点间的通讯关系信息;
66.s6,根据通讯关系信息生成区块链公链网络结构。
67.在上述实现过程中,通过构建探测包,主动向目标节点进行探测获得节点间的通讯关系信息,从而建立区块链公链各个节点间的连接关系,生成网络结构,可以提高生成网络结构的效率的同时,不会对区块链的安全造成影响。
68.自区块链爆发以来,公链项目得到了蓬勃发展,公链项目的竞争也可以说是白热化的。区块链公链也称公有链,公有链是指全世界任何人都可以随时进入到系统中读取数据、发送可确认交易、竞争记账的区块链。
69.区块链网络采用的是p2p覆盖网络。p2p网络,即对等网络,也称点对点网络或端对端网络,它是一种网络结构的思想,与目前网络中占据主导地位的客户端/服务器结构的本质区别是,整个网络结构中不存在中心节点(或中心服务器),通过p2p网络,不同节点之间可以直接交互,而且彼此连接的每个节点都处于对等的地位。由于去中心化的特性,区块链采用p2p网络作为其底层的网络结构变得十分自然,区块链中的节点在p2p 网络中通过运行特定的发现算法相互发现,进而建立直接的通道进行通信。
70.区块链公链采用的是p2p覆盖网络,公链的网络数据交换采用泛洪的方式传输,即首先将数据转发给目标节点,然后目标节点继续将数据转发给自己的目标节点。以此类推,直到将数据传到公链网络中的所有节点。
71.本技术实施例通过对区块链公链上多个节点的探测,建立网络拓扑图,能够了解公链上其他节点之间进行数据交换的通讯关系,能够描述出整个公链网络结构的全貌,能够及时的监测到整个公链网络结构的变化,也能够展示出整个公链网络中不同客户端及不同版本的分布情况。
72.在s1中,查找待识别探测的区块链公链的官方api接口文档,可选地,区块链公链可以是虚拟信息。
73.在s2中,通过对api接口文档的解读和分析,找出所需的api接口方法,常用到的两个方法分别是:获取节点常规信息和获取节点列表。可选地,还可以对api接口方法进行分析,判断是符合http get请求方法还是符合http post请求方法。
74.区块链公链的网络结构大多都可以通过api接口实现,api接口方法采用http get或http post方法去请求api接口,响应为json-rpc 形式。可通过在区块链公链中部署探针节点,并构造探测数据包,采用主动探测方式,进而实现整个公链网络结构的探测。
75.进一步地,s4包括:
76.发送第一探测包至目标节点,以使目标节点返回第一响应信息;
77.接收目标节点的第一响应信息;
78.根据第一响应信息和节点列表构建第二探测包。
79.在上述实现过程中,通过第一探测包对目标节点的探测,得到第一响应信息,再根据第一响应信息和节点列表构建第二探测包的方式,层层深入地对目标节点进行探测,提高对目标节点探测的效率。
80.根据节点常规信息构造第一探测包。由于不同虚拟信息的api接口方法是不同的,所以根据节点常规信息的不同,第一构造包中的信息数据也是不同的。主动对目标节点发送第一探测包探测,接收目标节点的第一响应信息,从第一响应信息中获取待识别探测的虚拟信息的特征信息,特征信息包括多个维度特征,如:协议、产品名称、版本号、节点状态、块数、高度、节点总数等等。其中,协议、产品名称、版本号为重要识别特征,节点状态、块数、高度、节点总数为辅助识别特征,如遇到部分重要识别特征缺失的情况,可以用辅助识别特征进行识别,以提高识别的准确性,来确定具体的虚拟信息产品。
81.进一步地,根据第一响应信息和节点列表构建第二探测包的步骤,包括:
82.根据第一响应信息获得区块链公链的特征信息;
83.根据特征信息确定产品名称;
84.根据产品名称和节点列表构建第二探测包。
85.在上述实现过程中,获得区块链公链的特征信息,进而确定产品名称,根据产品名称和节点列表构建第二探测包,使得构建的第二探测包更加准确,可以包含更多的节点信息。
86.在确定具体的虚拟信息的产品名称后,根据节点列表构造第二探测包,主动对目标节点发送第二探测包进行探测。
87.进一步地,s5包括:
88.根据第二探测包对目标节点进行探测,得到第二响应信息;
89.根据第二响应信息获得节点间的通讯关系信息。
90.在上述实现过程中,对目标节点进行探测后得到第二响应信息,根据第二响应信息获得通讯关系信息,使得通讯关系信息更加准确,可以反应出节点间的联系,提高探测效率。
91.进一步地,根据第二探测包对目标节点进行探测,得到第二响应信息的步骤,包括:
92.发送第二探测包至目标节点,以使目标节点返回第二响应信息;
93.接收目标节点的第二响应信息。
94.在上述实现过程中,主动对目标节点进行探测,可以直接、快速地获取到目标节点的信息,确保第二响应信息中包含更多的目标节点的信息,有助于提高后续生成网络结构的准确性。
95.进一步地,接收目标节点的第二响应信息的步骤,包括:
96.获取目标节点的响应状态码;
97.判断响应状态码是否为200;
98.若是,接收目标节点的第二响应信息。
99.在上述实现过程中,根据目标节点的响应状态码的数值判断是否接收第二响应信息,可以保证得到的第二响应信息的准确性,提高接收效率。
100.通过对目标节点的响应状态码进行判断,可选地,响应状态码可以是 http响应状态码,http响应状态码为200时,接收目标节点的第二响应信息。
101.进一步地,根据第二响应信息获得节点间的通讯关系信息的步骤,包括:
102.提取第二响应信息中的ip地址和端口信息;
103.根据ip地址和端口信息获得节点间的通讯关系信息。
104.在上述实现过程中,根据ip地址和端口信息获得节点间的通讯关系信息,使得到的通讯关系信息更加准确,有助于快速地寻找节点的端口信息。
105.根据json数据格式key:value,对第二响应信息进行判断,提取出第二响应信息中目标节点的ip地址和端口信息,并存储目标节点的邻节点的ip地址和端口信息到列表文件中。由于不同虚拟信息获取节点列表的api 接口方法是不同的,所以获取的节点列表信息是不同的,提取第二响应信息中的ip地址和端口信息的方法也是不同的。
106.将区块链公链中的所有节点的ip地址和端口信息提取出来,即可根据所有节点的ip地址和端口信息获得节点间的通讯关系信息,并根据节点间的通讯关系信息,生成区块链公链网络结构,可选地,网络结构可以用网络拓扑图展示。
107.网络拓扑图可以展示公链中不同客户端及不同版本的分布情况。方法如下:将同一产品名称作为拓扑的主节点,不同版本号作为次节点,然后再连接不同节点的ip地址。
108.本技术实施例,通过api接口发送合法的api请求的探测包,不会对区块链公链造成恶意破坏,并采用主动探测方式,节省资源,以较少资源推测发现每一个节点,进而实现全网探测。并且能够描述出公链网络结构的全貌,通过设置调整探测包的扫描周期,不断优化匹配过程,能够及时的监测到整个网络结构的变化。根据业务需求,也能够展示出整个公链中不同客户端及不同版本的分布情况。
109.实施例二
110.为了执行上述实施例一对应的方法,以实现相应的功能和技术效果,下面提供一种区块链公链网络结构的获取装置,如图2所示,该装置包括:
111.获取模块1,用于获取区块链公链的接口文档信息;
112.解析模块2,用于对接口文档信息进行解析,得到节点常规信息和节点列表;
113.构建模块3,用于根据节点常规信息构建第一探测包;还用于根据第一探测包和节点列表构建第二探测包;
114.连接模块4,用于根据第二探测包获得节点间的通讯关系信息;
115.生成模块5,用于根据通讯关系信息生成区块链公链网络结构。
116.在上述实现过程中,通过构建探测包,主动向目标节点进行探测获得节点间的通讯关系信息,从而建立区块链公链各个节点间的连接关系,生成网络结构,可以提高生成网络结构的效率的同时,不会对区块链的安全造成影响。
117.构建模块3还用于:
118.发送第一探测包至目标节点,以使目标节点返回第一响应信息;
119.接收目标节点的第一响应信息;
120.根据第一响应信息和节点列表构建第二探测包。
121.在上述实现过程中,通过第一探测包对目标节点的探测,得到第一响应信息,再根据第一响应信息和节点列表构建第二探测包的方式,层层深入地对目标节点进行探测,提高对目标节点探测的效率。
122.构建模块3还用于:
123.根据第一响应信息获得区块链公链的特征信息;
124.根据特征信息确定产品名称;
125.根据产品名称和节点列表构建第二探测包。
126.在上述实现过程中,获得区块链公链的特征信息,进而确定产品名称,根据产品名称和节点列表构建第二探测包,使得构建的第二探测包更加准确,可以包含更多的节点信息。
127.连接模块4还用于:
128.根据第二探测包对目标节点进行探测,得到第二响应信息;
129.根据第二响应信息获得节点间的通讯关系信息。
130.在上述实现过程中,对目标节点进行探测后得到第二响应信息,根据第二响应信息获得通讯关系信息,使得通讯关系信息更加准确,可以反应出节点间的联系,提高探测效率。
131.连接模块4还用于:
132.发送第二探测包至目标节点,以使目标节点返回第二响应信息;
133.接收目标节点的第二响应信息。
134.在上述实现过程中,主动对目标节点进行探测,可以直接、快速地获取到目标节点的信息,确保第二响应信息中包含更多的目标节点的信息,有助于提高后续生成网络结构的准确性。
135.连接模块4还用于:
136.获取目标节点的响应状态码;
137.判断响应状态码是否为200;
138.若是,接收目标节点的第二响应信息。
139.在上述实现过程中,根据目标节点的响应状态码的数值判断是否接收第二响应信息,可以保证得到的第二响应信息的准确性,提高接收效率。
140.连接模块4还用于:
141.提取第二响应信息中的ip地址和端口信息;
142.根据ip地址和端口信息获得节点间的通讯关系信息。
143.在上述实现过程中,根据ip地址和端口信息获得节点间的通讯关系信息,使得到的通讯关系信息更加准确,有助于快速地寻找节点的端口信息。
144.上述的区块链公链网络结构的获取装置可实施上述实施例一的方法。上述实施例一中的可选项也适用于本实施例,这里不再详述。
145.本技术实施例的其余内容可参照上述实施例一的内容,在本实施例中,不再进行赘述。
146.实施例三
147.本技术实施例提供一种电子设备,包括存储器及处理器,该存储器用于存储计算机程序,该处理器运行计算机程序以使电子设备执行实施例一的区块链公链网络结构的获取方法。
148.可选地,上述电子设备可以是服务器。
149.请参见图3,图3为本技术实施例提供的电子设备的结构组成示意图。该电子设备可以包括处理器31、通信接口32、存储器33和至少一个通信总线34。其中,通信总线34用于实现这些组件直接的连接通信。其中,本技术实施例中设备的通信接口32用于与其他节点
设备进行信令或数据的通信。处理器31可以是一种集成电路芯片,具有信号的处理能力。
150.上述的处理器31可以是通用处理器,包括中央处理器(centralprocessingunit,cpu)、网络处理器(networkprocessor,np)等;还可以是数字信号处理器(dsp)、专用集成电路(asic)、现成可编程门阵列(fpga)或者其他可编程逻辑器件、分立门或者晶体管逻辑器件、分立硬件组件。可以实现或者执行本技术实施例中的公开的各方法、步骤及逻辑框图。通用处理器可以是微处理器或者该处理器31也可以是任何常规的处理器等。
151.存储器33可以是,但不限于,随机存取存储器(randomaccessmemory,ram),只读存储器(readonlymemory,rom),可编程只读存储器(programmableread-onlymemory,prom),可擦除只读存储器(erasableprogrammableread-onlymemory,eprom),电可擦除只读存储器(electricerasableprogrammableread-onlymemory,eeprom)等。存储器33中存储有计算机可读取指令,当计算机可读取指令由所述处理器31执行时,设备可以执行上述图1方法实施例涉及的各个步骤。
152.可选地,电子设备还可以包括存储控制器、输入输出单元。存储器33、存储控制器、处理器31、外设接口、输入输出单元各元件相互之间直接或间接地电性连接,以实现数据的传输或交互。例如,这些元件相互之间可通过一条或多条通信总线34实现电性连接。处理器31用于执行存储器33中存储的可执行模块,例如设备包括的软件功能模块或计算机程序。
153.输入输出单元用于提供给用户创建任务以及为该任务创建启动可选时段或预设执行时间以实现用户与服务器的交互。输入输出单元可以是,但不限于,鼠标和键盘等。
154.可以理解,图3所示的结构仅为示意,电子设备还可包括比图3中所示更多或者更少的组件,或者具有与图3所示不同的配置。图3中所示的各组件可以采用硬件、软件或其组合实现。
155.另外,本技术实施例还提供一种计算机可读存储介质,其存储有计算机程序,该计算机程序被处理器执行时实现实施例一的区块链公链网络结构的获取方法。
156.本技术实施例还提供一种计算机程序产品,该计算机程序产品在计算机上运行时,使得计算机执行方法实施例所述的方法。
157.在本技术所提供的几个实施例中,应该理解到,所揭露的装置和方法,也可以通过其它的方式实现。以上所描述的装置实施例仅仅是示意性的,例如,附图中的流程图和框图显示了根据本技术的多个实施例的装置、方法和计算机程序产品的可能实现的体系架构、功能和操作。在这点上,流程图或框图中的每个方框可以代表一个模块、程序段或代码的一部分,所述模块、程序段或代码的一部分包含一个或多个用于实现规定的逻辑功能的可执行指令。也应当注意,在有些作为替换的实现方式中,方框中所标注的功能也可以以不同于附图中所标注的顺序发生。例如,两个连续的方框实际上可以基本并行地执行,它们有时也可以按相反的顺序执行,这依所涉及的功能而定。也要注意的是,框图和/或流程图中的每个方框、以及框图和/或流程图中的方框的组合,可以用执行规定的功能或动作的专用的基于硬件的装置来实现,或者可以用专用硬件与计算机指令的组合来实现。
158.另外,在本技术各个实施例中的各功能模块可以集成在一起形成一个独立的部分,也可以是各个模块单独存在,也可以两个或两个以上模块集成形成一个独立的部分。
159.所述功能如果以软件功能模块的形式实现并作为独立的产品销售或使用时,可以存储在一个计算机可读取存储介质中。基于这样的理解,本技术的技术方案本质上或者说
对现有技术做出贡献的部分或者该技术方案的部分可以以软件产品的形式体现出来,该计算机软件产品存储在一个存储介质中,包括若干指令用以使得一台计算机设备(可以是个人计算机,服务器,或者网络设备等)执行本技术各个实施例所述方法的全部或部分步骤。而前述的存储介质包括:u盘、移动硬盘、rom、ram、磁碟或者光盘等各种可以存储程序代码的介质。
160.以上所述仅为本技术的实施例而已,并不用于限制本技术的保护范围,对于本领域的技术人员来说,本技术可以有各种更改和变化。凡在本技术的精神和原则之内,所作的任何修改、等同替换、改进等,均应包含在本技术的保护范围之内。应注意到:相似的标号和字母在下面的附图中表示类似项,因此,一旦某一项在一个附图中被定义,则在随后的附图中不需要对其进行进一步定义和解释。
161.以上所述,仅为本技术的具体实施方式,但本技术的保护范围并不局限于此,任何熟悉本技术领域的技术人员在本技术揭露的技术范围内,可轻易想到变化或替换,都应涵盖在本技术的保护范围之内。因此,本技术的保护范围应所述以权利要求的保护范围为准。
162.需要说明的是,在本文中,诸如第一和第二等之类的关系术语仅仅用来将一个实体或者操作与另一个实体或操作区分开来,而不一定要求或者暗示这些实体或操作之间存在任何这种实际的关系或者顺序。而且,术语“包括”、“包含”或者其任何其他变体意在涵盖非排他性的包含,从而使得包括一系列要素的过程、方法、物品或者设备不仅包括那些要素,而且还包括没有明确列出的其他要素,或者是还包括为这种过程、方法、物品或者设备所固有的要素。在没有更多限制的情况下,由语句“包括一个
……”
限定的要素,并不排除在包括所述要素的过程、方法、物品或者设备中还存在另外的相同要素。
当前第1页1 2 
网友询问留言 已有0条留言
  • 还没有人留言评论。精彩留言会获得点赞!
1