本发明涉及计算机技术领域,特别涉及一种验证交易的方法、一种节点及一种区块链系统。
背景技术:
随着计算机技术的快速发展,网络交易越来越多。在现有技术中,网络交易的交易信息通过网络进行传输,接收到该交易信息的节点无法对该交易信息对应的交易进行验证。
技术实现要素:
本发明实施例提供了一种验证交易的方法、一种节点及一种区块链系统,能够对交易进行验证。
第一方面,本发明实施例提供了一种验证交易的方法,应用于区块链网络中的任一节点,在所述区块链网络中的每个节点中保存有与其他节点的共享密钥;包括:
当所述区块链网络中的任一节点发起交易时,该节点执行:
根据交易信息,生成第一哈希标签;
针对所述区块链网络中的每个其他节点,执行:获取与当前的其他节点的共享密钥,根据所述第一哈希标签、所述交易信息和与当前的其他节点的共享密钥,生成当前的其他节点对应的第二哈希标签;
根据所述交易信息、所述第一哈希标签和每个其他节点对应的第二哈希标签,生成广播信息;
将所述广播信息广播到所述区块链网络中,以使每个其他节点执行:接收广播信息,根据接收到的广播信息,以及当前的其他节点与发出所述广播信息的节点的共享密钥,生成待验证哈希标签,从接收到的广播信息中获取当前的其他节点对应的第二哈希标签,判断获取的当前的其他节点对应的第二哈希标签是否与所述待验证哈希标签相同,如果是,则确定发出所述广播信息的节点发起的交易通过验证。
优选地,
所述根据交易信息,生成第一哈希标签,包括:
将预先设置的秘密值作为带密钥的哈希算法的输入密钥;
根据所述秘密值,利用所述带密钥的哈希算法计算所述交易信息的所述第一哈希标签。
优选地,
所述根据所述第一哈希标签、所述交易信息和与当前的其他节点的共享密钥,生成当前的其他节点对应的第二哈希标签,包括:
将与当前的其他节点的共享密钥作为带密钥的哈希算法的输入密钥;
将所述交易信息和所述第一哈希标签拼接成中间信息;
根据与当前的其他节点的共享密钥,利用所述带密钥的哈希算法计算所述中间信息的第二哈希标签。
优选地,
所述根据所述交易信息、所述第一哈希标签和每个其他节点对应的第二哈希标签,生成广播信息,包括:
根据第一式子,将所述交易信息、所述第一哈希标签和每个其他节点对应的第二哈希标签拼接成所述广播信息,其中,所述第一式子为:
g=j||h||h1||h2||…hi…||hn;
其中,g为所述广播信息,j为所述交易信息,h为所述第一哈希标签,hi为第i个其他节点对应的第二哈希标签,i=1,2,…,n。
第二方面,本发明实施例提供了一种节点,包括:
第一哈希单元,用于根据交易信息,生成第一哈希标签;
第二哈希单元,用于针对区块链网络中的每个其他节点,执行:获取与当前的其他节点的共享密钥,根据所述第一哈希标签、所述交易信息和与当前的其他节点的共享密钥,生成当前的其他节点对应的第二哈希标签;
广播信息生成单元,用于根据所述交易信息、所述第一哈希标签和每个其他节点对应的第二哈希标签,生成广播信息;
广播单元,用于将所述广播信息广播到所述区块链网络中,以使每个其他节点执行:接收广播信息,根据接收到的广播信息,以及当前的其他节点与发出所述广播信息的节点的共享密钥,生成待验证哈希标签,从接收到的广播信息中获取当前的其他节点对应的第二哈希标签,判断获取的当前的其他节点对应的第二哈希标签是否与所述待验证哈希标签相同,如果是,则确定发出所述广播信息的节点发起的交易通过验证;
其中,在所述区块链网络中的每个节点中保存有与其他节点的共享密钥。
优选地,
所述第一哈希单元,用于将预先设置的秘密值作为带密钥的哈希算法的输入密钥;根据所述秘密值,利用所述带密钥的哈希算法计算所述交易信息的所述第一哈希标签。
优选地,
所述第二哈希单元,在执行所述根据所述第一哈希标签、所述交易信息和与当前的其他节点的共享密钥,生成当前的其他节点对应的第二哈希标签时,具体用于:
将与当前的其他节点的共享密钥作为带密钥的哈希算法的输入密钥;
将所述交易信息和所述第一哈希标签拼接成中间信息;
根据与当前的其他节点的共享密钥,利用所述带密钥的哈希算法计算所述中间信息的第二哈希标签。
优选地,
所述广播信息生成单元,用于根据第一式子,将所述交易信息、所述第一哈希标签和每个其他节点对应的第二哈希标签拼接成所述广播信息,其中,所述第一式子为:
g=j||h||h1||h2||…hi…||hn;
其中,g为所述广播信息,j为所述交易信息,h为所述第一哈希标签,hi为第i个其他节点对应的第二哈希标签,i=1,2,…,n。
第三方面,本发明实施例提供了一种区块链系统,包括:
多个节点;
其中,每个节点中保存有与其他节点的共享密钥;
针对每个节点,在当前节点发起交易时,当前节点作为发起节点,在其他节点发起交易时,当前节点作为接收节点;
所述节点,用于当作为发起节点时,执行:
根据交易信息,生成第一哈希标签;
针对每个其他节点,执行:获取与当前的其他节点的共享密钥,根据所述第一哈希标签、所述交易信息和与当前的其他节点的共享密钥,生成当前的其他节点对应的第二哈希标签;
根据所述交易信息、所述第一哈希标签和每个其他节点对应的第二哈希标签,生成广播信息,将该广播信息广播到区块链网络中;
所述节点,用于当作为接收节点时,执行:
接收到区块链网络中的广播信息,根据接收到的广播信息,以及与发出该广播信息的节点的共享密钥,生成待验证哈希标签,从接收到的广播信息中获取本节点对应的第二哈希标签,判断获取的本节点对应的第二哈希标签是否与所述待验证哈希标签相同,如果是,则确定发出该广播信息的节点发起的交易通过验证。
优选地,
所述节点,当作为发起节点时,在执行所述根据所述第一哈希标签、所述交易信息和与当前的其他节点的共享密钥,生成当前的其他节点对应的第二哈希标签时,具体用于包括:
将与当前的其他节点的共享密钥作为带密钥的哈希算法的输入密钥;
将交易信息和第一哈希标签拼接成中间信息;
根据与当前的其他节点的共享密钥,利用所述带密钥的哈希算法计算所述中间信息的第二哈希标签;
所述节点,当作为接收节点时,在执行所述根据接收到的广播信息,以及与发出该广播信息的节点的共享密钥,生成待验证哈希标签时,具体用于:
根据接收到的广播信息,确定接收到的广播信息中的交易信息和第一哈希标签;
将与发出该广播信息的节点的共享密钥作为带密钥的哈希算法的输入密钥;
将接收到的广播信息中的交易信息和第一哈希标签拼接成待计算信息;
根据与发出该广播信息的节点的共享密钥,利用带密钥的哈希算法计算所述待计算信息的所述待验证哈希标签。
在本发明实施例中,在区块链网络中的每个两个节点之间有一个共享密钥,发起交易的节点根据交易信息生成第一哈希标签,然后,根据第一哈希标签、交易信息和与其他节点的共享密钥,生成第二哈希标签,根据交易信息、第一哈希标签和每个其他节点对应的第二哈希标签,生成广播信息,并广播到区块链网络中,区块链网络中的节点都可以接收到该广播信息,在接收到该广播信息后,接收到该广播信息的节点根据该广播信息和与发出广播信息的节点的共享密钥,生成待验证哈希标签,将该待验证哈希标签与广播信息中对应的第二哈希标签进行比较,如果相同则确定该交易通过验证,实现对交易的验证
附图说明
为了更清楚地说明本发明实施例或现有技术中的技术方案,下面将对实施例或现有技术描述中所需要使用的附图作简单地介绍,显而易见地,下面描述中的附图是本发明的一些实施例,对于本领域普通技术人员来讲,在不付出创造性劳动的前提下,还可以根据这些附图获得其他的附图。
图1是本发明一实施例提供的一种验证交易的方法的流程图;
图2是本发明一实施例提供的另一种验证交易的方法的流程图;
图3是本发明一实施例提供的一种节点的示意图。
具体实施方式
为使本发明实施例的目的、技术方案和优点更加清楚,下面将结合本发明实施例中的附图,对本发明实施例中的技术方案进行清楚、完整地描述,显然,所描述的实施例是本发明一部分实施例,而不是全部的实施例,基于本发明中的实施例,本领域普通技术人员在没有做出创造性劳动的前提下所获得的所有其他实施例,都属于本发明保护的范围。
如图1所示,本发明实施例提供了一种验证交易的方法,应用于区块链网络中的任一节点,在所述区块链网络中的每个节点中保存有与其他节点的共享密钥,该方法包括:
当所述区块链网络中的任一节点发起交易时,该节点执行:
步骤101:根据交易信息,生成第一哈希标签;
步骤102:针对所述区块链网络中的每个其他节点,执行:获取与当前的其他节点的共享密钥,根据所述第一哈希标签、所述交易信息和与当前的其他节点的共享密钥,生成当前的其他节点对应的第二哈希标签;
步骤103:根据所述交易信息、所述第一哈希标签和每个其他节点对应的第二哈希标签,生成广播信息;
步骤104:将所述广播信息广播到所述区块链网络中,以使每个其他节点执行:接收广播信息,根据接收到的广播信息,以及当前的其他节点与发出所述广播信息的节点的共享密钥,生成待验证哈希标签,从接收到的广播信息中获取当前的其他节点对应的第二哈希标签,判断获取的当前的其他节点对应的第二哈希标签是否与所述待验证哈希标签相同,如果是,则确定发出所述广播信息的节点发起的交易通过验证。
在本发明实施例中,在区块链网络中的每个两个节点之间有一个共享密钥,发起交易的节点根据交易信息生成第一哈希标签,然后,根据第一哈希标签、交易信息和与其他节点的共享密钥,生成第二哈希标签,根据交易信息、第一哈希标签和每个其他节点对应的第二哈希标签,生成广播信息,并广播到区块链网络中,区块链网络中的节点都可以接收到该广播信息,在接收到该广播信息后,接收到该广播信息的节点根据该广播信息和与发出广播信息的节点的共享密钥,生成待验证哈希标签,将该待验证哈希标签与广播信息中对应的第二哈希标签进行比较,如果相同则确定该交易通过验证,实现对交易的验证
由于任意两个节点之间设置有共享密钥,只有通过相同的密钥,计算出的哈希标签才相同,如果不同,说明该交易的交易信息可能被篡改,或者,该交易的发起节点不安全,那么,该交易是不可信的,不能通过验证。
通过任一两个节点之间的唯一的共享密钥来生成哈希标签,比较发起交易的节点生成的第二哈希标签与接收到广播信息的节点生成的待验证哈希标签,即可实现对该交易的验证,并且能够保证不可篡改性和不可抵赖性。
下面通过发起交易的节点a和任一一个在区块链网络中的其他节点b为例,来说明该验证交易的方法:
节点a发起了交易,节点a根据与节点b的共享密钥kab,生成了针对节点b的第二哈希标签hab,发出广播信息;
节点b接收到节点a发出的广播信息后,根据与节点a的共享密钥kab,生成了待验证哈希标签,如果节点b判断出第二哈希标签hab与其生成的待验证哈希标签相同,则确定节点a发起的交易通过验证,该交易是可信的,并且该交易不可篡改、不可抵赖;如果节点a判断出第二哈希标签hab与其生成的待验证哈希标签不相同,则确定节点a发起的交易没有通过验证,该交易是不可信的。
在本发明一实施例中,所述根据交易信息,生成第一哈希标签,包括:
将预先设置的秘密值作为带密钥的哈希算法的输入密钥;
根据所述秘密值,利用所述带密钥的哈希算法计算所述交易信息的所述第一哈希标签。
在本发明实施例中,该秘密值可以是每个发起交易的节点自行设置。在生成第一哈希标签时,将秘密值和交易信息作为带密钥的哈希算法的输入,经过带密钥的哈希算法的处理后,生成第一哈希标签。
在本发明一实施例中,所述根据所述第一哈希标签、所述交易信息和与当前的其他节点的共享密钥,生成当前的其他节点对应的第二哈希标签,包括:
将与当前的其他节点的共享密钥作为带密钥的哈希算法的输入密钥;
将所述交易信息和所述第一哈希标签拼接成中间信息;
根据与当前的其他节点的共享密钥,利用所述带密钥的哈希算法计算所述中间信息的第二哈希标签。
在本发明实施例中,在生成第二哈希标签时,将共享密钥和中间信息作为带密钥的哈希算法的输入,经过带密钥的哈希算法的处理后,生成第二哈希标签。
在本发明一实施例中,所述根据所述交易信息、所述第一哈希标签和每个其他节点对应的第二哈希标签,生成广播信息,包括:
根据第一式子,将所述交易信息、所述第一哈希标签和每个其他节点对应的第二哈希标签拼接成所述广播信息,其中,所述第一式子为:
g=j||h||h1||h2||…hi…||hn;
其中,g为所述广播信息,j为所述交易信息,h为所述第一哈希标签,hi为第i个其他节点对应的第二哈希标签,i=1,2,…,n。
在本发明实施例中,广播信息有交易信息、第一哈希标签和每个其他节点对应的第二哈希标签拼接而成。其中,通过第一式子可见,在广播信息中,按照顺序依次是:j、h、h1、h2···hn。
接收到的广播信息的节点可以根据该广播信息确定出本节点对应的第二哈希标签。
如图2所示,从发起交易的节点a和接收节点a发出的广播信息的其他节点的交互来详细说明本发明实施例提供了一种验证交易的方法。在区块链网络中的每个节点中保存有与其他节点的共享密钥,例如:节点a和节点b均是区块链网络中的节点,节点a中保存有与节点b的共享密钥kab,节点b中也保存有与节点a的共享密钥kab。该方法可以包括以下步骤:
步骤201:节点a发起交易,生成交易信息。
举例来说,节点a发起了与节点c的交易,j={a(pka)支付3个密码货币给c(pkc)},其中,j为交易信息,pka为节点a的公钥,pkc为节点c的公钥,交易信息中包含交易发起者和接收者的公钥作为身份标识。
步骤202:节点a将预先设置的秘密值作为带密钥的哈希算法的输入密钥,根据秘密值,利用带密钥的哈希算法计算交易信息的第一哈希标签。
具体地,根据秘密值,利用带密钥的哈希算法计算交易信息的哈希标签,该哈希标签为第一哈希标签。
h=macka(j),其中,ka为节点a的秘密值,h为第一哈希标签,macka(j)表示根据秘密值ka,利用带密钥的哈希算法(mac)计算交易信息j的第一哈希标签h。
步骤203:节点a针对区块链网络中的每个其他节点,执行:获取与当前的其他节点的共享密钥,将与当前的其他节点的共享密钥作为带密钥的哈希算法的输入密,将交易信息和第一哈希标签拼接成中间信息,根据与当前的其他节点的共享密钥,利用带密钥的哈希算法计算中间信息的第二哈希标签。
具体地,节点a针对每个其他节点都生成对应的第二哈希标签,以节点b为例,节点a获取与节点b的共享密钥kab,将交易信息j和第一哈希h标签拼接成中间信息,该中间信息表示为j||h,根据与节点b的共享密钥kab,利用带密钥的哈希算法计算中间信息j||h的第二哈希标签hi,其中,节点b为第i个其他节点,第i个其他节点对应的第二哈希标签表示为hi。
hi=mackab(j||h)。
根据与当前的其他节点的共享密钥,利用带密钥的哈希算法计算中间信息的哈希标签,该哈希标签为当前的其他节点对应的第二哈希标签。
步骤204:节点a根据第一式子,将交易信息、第一哈希标签和每个其他节点对应的第二哈希标签拼接成广播信息,其中,第一式子为:
g=j||h||h1||h2||…hi…||hn;
其中,g为广播信息,j为交易信息,h为第一哈希标签,hi为第i个其他节点对应的第二哈希标签,i=1,2,…,n。
步骤205:节点a将广播信息广播到区块链网络中。
步骤206:区块链网络中的每个其他节点接收广播信息。
举例来说,节点b为区块链网络中的节点,节点b接收节点a发出的广播信息。
步骤207:每个其他节点,执行:从广播信息获取交易信息、第一哈希标签,以及本节点对应的第二哈希标签,将与节点a的共享密钥作为带密钥的哈希算法的输入密钥,将获取的交易信息和第一哈希标签拼接成待计算信息,根据与节点a的共享密钥,利用带密钥的哈希算法计算待计算信息的待验证哈希标签。
以节点b为例,节点b执行:
从广播信息获取交易信息j、第一哈希标签h,以及节点b对应的第二哈希标签hi;
将与节点a的共享密钥kab作为带密钥的哈希算法的输入密钥,将获取的交易信息j和第一哈希标签h拼接成待计算信息j||h;
根据与节点a的共享密钥kab,利用带密钥的哈希算法计算待计算信息j||h的待验证哈希标签。
步骤208:每个其他节点,执行:判断获取的本节点对应的第二哈希标签是否与待验证哈希标签相同,如果是,则确定节点a发起的交易通过验证,否则,确定节点a发起的交易不通过验证。
以节点b为例,节点b执行:
判断获取的节点b对应的第二哈希标签hi是否与节点b生成的待验证哈希标签相同,如果是,则确定节点a发起的交易通过验证,否则,确定节点a发起的交易不通过验证。
其中,带密钥的哈希算法可以是基于sha-3的消息认证码算法。
另外,任意两个节点的共享密钥可以通过以下方式生成:
第一节点获取第二节点共享的第二节点的公钥;
第一节点根据第二节点的公钥,确定与第二节点的共享密钥。
其中,第一节点根据第二节点的公钥,确定与第二节点的共享密钥,包括:
根据以下公式,确定第二节点公钥对应的共享函数:
v(x)=u(x)s(x)+e1(x)∈rq;
其中,v(x)表征共享函数,u(x)表征第二节点的公钥,s(x)表征预设的随机函数,e1(x)表征预设的误差函数,rq表征由奇素数q构成的实数域,其中,s(x)∈rrq,e1(x)←rχ;
确定共享函数的信号向量,并确定信号向量的舍入结果;
根据预设的划分规则,从舍入结果中划分出与第二节点的共享密钥。
在本发明实施例中,在节点之间两两建立共享密钥,在发起交易时,采用带密钥的哈希算法生成交易的哈希标签,其他节点可以利用与发起交易的节点的共享密钥验证交易的真实性,这样避免了通信开销过大和单个区块过大的问题。
如图3所示,本发明实施例提供了一种节点,包括:
第一哈希单元301,用于根据交易信息,生成第一哈希标签;
第二哈希单元302,用于针对区块链网络中的每个其他节点,执行:获取与当前的其他节点的共享密钥,根据所述第一哈希标签、所述交易信息和与当前的其他节点的共享密钥,生成当前的其他节点对应的第二哈希标签;
广播信息生成单元303,用于根据所述交易信息、所述第一哈希标签和每个其他节点对应的第二哈希标签,生成广播信息;
广播单元304,用于将所述广播信息广播到所述区块链网络中,以使每个其他节点执行:接收广播信息,根据接收到的广播信息,以及当前的其他节点与发出所述广播信息的节点的共享密钥,生成待验证哈希标签,从接收到的广播信息中获取当前的其他节点对应的第二哈希标签,判断获取的当前的其他节点对应的第二哈希标签是否与所述待验证哈希标签相同,如果是,则确定发出所述广播信息的节点发起的交易通过验证;
其中,在所述区块链网络中的每个节点中保存有与其他节点的共享密钥。
在本发明一实施例中,所述第一哈希单元,用于将预先设置的秘密值作为带密钥的哈希算法的输入密钥;根据所述秘密值,利用所述带密钥的哈希算法计算所述交易信息的所述第一哈希标签。
在本发明一实施例中,所述第二哈希单元,在执行所述根据所述第一哈希标签、所述交易信息和与当前的其他节点的共享密钥,生成当前的其他节点对应的第二哈希标签时,具体用于:
将与当前的其他节点的共享密钥作为带密钥的哈希算法的输入密钥;
将所述交易信息和所述第一哈希标签拼接成中间信息;
根据与当前的其他节点的共享密钥,利用所述带密钥的哈希算法计算所述中间信息的第二哈希标签。
在本发明一实施例中,所述广播信息生成单元,用于根据第一式子,将所述交易信息、所述第一哈希标签和每个其他节点对应的第二哈希标签拼接成所述广播信息,其中,所述第一式子为:
g=j||h||h1||h2||…hi…||hn;
其中,g为所述广播信息,j为所述交易信息,h为所述第一哈希标签,hi为第i个其他节点对应的第二哈希标签,i=1,2,…,n。
本发明实施例提供了一种区块链系统,包括:
多个节点;
其中,每个节点中保存有与其他节点的共享密钥;
针对每个节点,在当前节点发起交易时,当前节点作为发起节点,在其他节点发起交易时,当前节点作为接收节点;
所述节点,用于当作为发起节点时,执行:
根据交易信息,生成第一哈希标签;
针对每个其他节点,执行:获取与当前的其他节点的共享密钥,根据所述第一哈希标签、所述交易信息和与当前的其他节点的共享密钥,生成当前的其他节点对应的第二哈希标签;
根据所述交易信息、所述第一哈希标签和每个其他节点对应的第二哈希标签,生成广播信息,将该广播信息广播到区块链网络中;
所述节点,用于当作为接收节点时,执行:
接收到区块链网络中的广播信息,根据接收到的广播信息,以及与发出该广播信息的节点的共享密钥,生成待验证哈希标签,从接收到的广播信息中获取本节点对应的第二哈希标签,判断获取的本节点对应的第二哈希标签是否与所述待验证哈希标签相同,如果是,则确定发出该广播信息的节点发起的交易通过验证。
在本发明实施例中,每个节点即具有发起节点的功能,也具有接收节点的功能。
在本发明一实施例中,所述节点,当作为发起节点时,在执行所述根据所述第一哈希标签、所述交易信息和与当前的其他节点的共享密钥,生成当前的其他节点对应的第二哈希标签时,具体用于包括:
将与当前的其他节点的共享密钥作为带密钥的哈希算法的输入密钥;
将交易信息和第一哈希标签拼接成中间信息;
根据与当前的其他节点的共享密钥,利用所述带密钥的哈希算法计算所述中间信息的第二哈希标签;
所述节点,当作为接收节点时,在执行所述根据接收到的广播信息,以及与发出该广播信息的节点的共享密钥,生成待验证哈希标签时,具体用于:
根据接收到的广播信息,确定接收到的广播信息中的交易信息和第一哈希标签;
将与发出该广播信息的节点的共享密钥作为带密钥的哈希算法的输入密钥;
将接收到的广播信息中的交易信息和第一哈希标签拼接成待计算信息;
根据与发出该广播信息的节点的共享密钥,利用带密钥的哈希算法计算所述待计算信息的所述待验证哈希标签。
本发明各个实施例至少具有如下有益效果:
1、在本发明实施例中,在区块链网络中的每个两个节点之间有一个共享密钥,发起交易的节点根据交易信息生成第一哈希标签,然后,根据第一哈希标签、交易信息和与其他节点的共享密钥,生成第二哈希标签,根据交易信息、第一哈希标签和每个其他节点对应的第二哈希标签,生成广播信息,并广播到区块链网络中,区块链网络中的节点都可以接收到该广播信息,在接收到该广播信息后,接收到该广播信息的节点根据该广播信息和与发出广播信息的节点的共享密钥,生成待验证哈希标签,将该待验证哈希标签与广播信息中对应的第二哈希标签进行比较,如果相同则确定该交易通过验证,实现对交易的验证
2、在本发明实施例中,通过任一两个节点之间的唯一的共享密钥来生成哈希标签,比较发起交易的节点生成的第二哈希标签与接收到广播信息的节点生成的待验证哈希标签,即可实现对该交易的验证,并且能够保证不可篡改性和不可抵赖性。
需要说明的是,在本文中,诸如第一和第二之类的关系术语仅仅用来将一个实体或者操作与另一个实体或操作区分开来,而不一定要求或者暗示这些实体或操作之间存在任何这种实际的关系或者顺序。而且,术语“包括”、“包含”或者其任何其他变体意在涵盖非排他性的包含,从而使得包括一系列要素的过程、方法、物品或者设备不仅包括那些要素,而且还包括没有明确列出的其他要素,或者是还包括为这种过程、方法、物品或者设备所固有的要素。在没有更多限制的情况下,由语句“包括一个……”限定的要素,并不排除在包括所述要素的过程、方法、物品或者设备中还存在另外的相同因素。
本领域普通技术人员可以理解:实现上述方法实施例的全部或部分步骤可以通过程序指令相关的硬件来完成,前述的程序可以存储在计算机可读取的存储介质中,该程序在执行时,执行包括上述方法实施例的步骤;而前述的存储介质包括:rom、ram、磁碟或者光盘等各种可以存储程序代码的介质中。
最后需要说明的是:以上所述仅为本发明的较佳实施例,仅用于说明本发明的技术方案,并非用于限定本发明的保护范围。凡在本发明的精神和原则之内所做的任何修改、等同替换、改进等,均包含在本发明的保护范围内。