CN109409884A - 一种基于sm9算法的区块链隐私保护方案和系统 - Google Patents
一种基于sm9算法的区块链隐私保护方案和系统 Download PDFInfo
- Publication number
- CN109409884A CN109409884A CN201811245996.7A CN201811245996A CN109409884A CN 109409884 A CN109409884 A CN 109409884A CN 201811245996 A CN201811245996 A CN 201811245996A CN 109409884 A CN109409884 A CN 109409884A
- Authority
- CN
- China
- Prior art keywords
- group
- node
- kgc
- transaction
- block
- Prior art date
- Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
- Pending
Links
Classifications
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F21/00—Security arrangements for protecting computers, components thereof, programs or data against unauthorised activity
- G06F21/60—Protecting data
- G06F21/64—Protecting data integrity, e.g. using checksums, certificates or signatures
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06Q—INFORMATION AND COMMUNICATION TECHNOLOGY [ICT] SPECIALLY ADAPTED FOR ADMINISTRATIVE, COMMERCIAL, FINANCIAL, MANAGERIAL OR SUPERVISORY PURPOSES; SYSTEMS OR METHODS SPECIALLY ADAPTED FOR ADMINISTRATIVE, COMMERCIAL, FINANCIAL, MANAGERIAL OR SUPERVISORY PURPOSES, NOT OTHERWISE PROVIDED FOR
- G06Q20/00—Payment architectures, schemes or protocols
- G06Q20/38—Payment protocols; Details thereof
- G06Q20/382—Payment protocols; Details thereof insuring higher security of transaction
- G06Q20/3829—Payment protocols; Details thereof insuring higher security of transaction involving key management
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06Q—INFORMATION AND COMMUNICATION TECHNOLOGY [ICT] SPECIALLY ADAPTED FOR ADMINISTRATIVE, COMMERCIAL, FINANCIAL, MANAGERIAL OR SUPERVISORY PURPOSES; SYSTEMS OR METHODS SPECIALLY ADAPTED FOR ADMINISTRATIVE, COMMERCIAL, FINANCIAL, MANAGERIAL OR SUPERVISORY PURPOSES, NOT OTHERWISE PROVIDED FOR
- G06Q20/00—Payment architectures, schemes or protocols
- G06Q20/38—Payment protocols; Details thereof
- G06Q20/40—Authorisation, e.g. identification of payer or payee, verification of customer or shop credentials; Review and approval of payers, e.g. check credit lines or negative lists
- G06Q20/401—Transaction verification
- G06Q20/4014—Identity check for transactions
Landscapes
- Engineering & Computer Science (AREA)
- Business, Economics & Management (AREA)
- Computer Security & Cryptography (AREA)
- Accounting & Taxation (AREA)
- Theoretical Computer Science (AREA)
- General Physics & Mathematics (AREA)
- Physics & Mathematics (AREA)
- Finance (AREA)
- General Business, Economics & Management (AREA)
- Strategic Management (AREA)
- Health & Medical Sciences (AREA)
- Bioethics (AREA)
- General Health & Medical Sciences (AREA)
- Computer Hardware Design (AREA)
- Software Systems (AREA)
- General Engineering & Computer Science (AREA)
- Storage Device Security (AREA)
Abstract
本发明公开了一种基于我国SM9商用密码算法的区块链隐私保护方案和系统,属于区块链安全与隐私保护领域。提供了一种基于联盟链的节点间交易平台,定义了平台中各类节点的权限与功能,交易平台支持节点交易,信息验证,参数维护,区块生成等功能;描述了一种改进SM9多KGC(密钥产生中心)签名算法,该算法对SM9算法中单KGC工作模式进行改进,适应联盟链结构,节点间在交易时采用该算法确定对方身份;提出了一种基于SM9算法的群签名方案,将SM9算法的身份验证改进为群签名验证,有效保护了签名方的身份隐私,节点交易后将交易信息通过该算法进行群签名并写入区块链中,可有效隐藏交易双方身份信息,在保护了节点隐私的同时保证了交易的合法性。
Description
技术领域
本发明属于区块链安全与隐私保护领域,具体涉及一种基于联盟区块链的隐私保护方案和系统架构设计。
背景技术
区块链技术因其“去中心化”与“去信任化”等特点,可在可信第三方不参与的情况下与陌生节点之间进行安全的信息传递,从而可有效提高信息交互效率,降低交互成本,在比特币、供应链等领域具有较为广阔的应用前景。哈希算法以及数字签名算法在区块链中应用广泛,用以验证区块以及交易的正确性。区块链在实际场景中应用时,不仅仅需要核验节点的公钥地址,还应验证各个节点的真实身份。传统的PKI体制因为可信中心的权重过大,不符合区块链“去中心化”与“去信任化”的特点。因此,无证书的加密与签名方案可以在区块链技术中得到应用。
隐私泄露是区块链技术中不容忽视的问题。与传统中心化结构不同,区块链机制不依赖特定中心节点处理与存储数据,因此可以避免恶意中心或因其他原因导致的中心信息泄露。但为了验证交易信息,区块链中的所有交易记录必须公开,因此将显著增加信息泄露风险。交易地址暴露于区块链环境中容易被跟踪查找。因为区块链技术与当前IT架构存在区别,以往的隐私保护方案并不适用。所以,区块链的隐私保护需要更具针对性的机制。
专利文献1(公开号:CN106534085A,公开日2017年3月22日)提供了一种基于区块链技术的隐私保护方法,设计引入非对称加密方案,对隐私数据进行区块化封装,并对其进行加密保护。可以在保护密文数据隐私性的前提下,支持在区块链环境下进行交易流程,同时保证了执行效率。但该发明侧重点在于保护区块中相关敏感数据的隐私,通过加密手段使得非授权人员无法解密得到相关信息,而并未能隐藏提交数据的节点身份,从而仍有相关隐私信息泄露的风险,同时由于加解密流程需验证身份,则需要引入PKI体系,难以适应区块链高度去中心化的架构体系。
专利文献2(公开号:CN107911216A,公开日2018年4月13日)提供了一种区块链交易隐私保护方法及系统。该发明主要基于联盟链环境,侧重描述利用群签名技术保护节点交易信息隐私,同时记账节点也可使用私钥打开信息,追踪信息来源。但其公开的交易信息中含有交易节点的私钥签名,交易确认阶段会面临节点伪造的问题。且该发明基于联盟区块链环境,记账节点需要持有大量用户私钥数据以验证交易信息,在增大管理难度的同时,也存在严重的信息泄露风险。
针对上述发明的不完善之处,本发明通过模式创新,采用基于功能需求的密文服务策略,构造了一种基于SM9算法的区块链隐私保护方案和系统,支持节点间安全可信交易,联盟链区块高效生成,交易信息确认以及节点隐私保护等功能。对现有SM9算法进行改进,提出一种SM9多KGC签名算法,弥补其所存在的不足,并提出一种基于SM9算法的群签名方案,以区块链中的联盟链为应用环境,实现对交易过程的隐私保护。实现效率较现有方案相比,所需指数运算与双线性对运算均有减少,运算效率有所提升。
发明内容
为了克服上述现有技术的不足,本发明从安全性、匿名性与运算效率等多方面综合因素考虑,设计了一种基于SM9算法的区块链隐私保护方案和系统。
与现有技术相比,本发明主要存在如下三方面有益效果:
(1)解决了区块链架构难以应用于现实场景的问题
由于区块链环境下,节点间多使用公钥定义自身身份进行交易,因交易物为相关数字货币,故无需验证对方真实身份,但现实场景中双方进行信息沟通时,必须通过数字证书验证对方合法身份,而因区块链去中心化的特点,导致传统数字证书体系无法适用于区块链结构。本发明通过引入并改进基于身份的SM9标识密码算法,利用其无证书特性,可使节点在无可信第三方情况下验证对方真实身份,解决了区块链技术在现实场景中的应用问题。
(2)解决了当前区块链环境节点交易过程中的隐私泄漏问题
当前区块链技术的应用场景中,节点间多以固定公钥地址进行交易,若进行交易追踪,可较易推断出参与交易节点的真实身份,导致交易双方身份隐私的泄露。本发明通过提供一种基于SM9算法的群签名方案,在交易信息写入区块时使用群签名,有效隐藏节点身份信息,同时确保同一节点两次不同交易无法判断关联性,在节点交易信息确认过程中保护了节点的身份隐私。
(3)设计了新的联盟区块链工作模式,增大联盟链结构的去中心化程度
在现有联盟区块链应用中,主要节点负责承担大部分区块链相关的运算工作,如区块生成,交易信息确认等等,次要节点仅参与交易,在授权后才能查看区块,中心化程度依然较高。本发明提供了一种新的联盟链工作模式,进一步减少主要节点的权限与工作量,将交易信息确认交由次要节点完成,大幅降低主要节点的工作量,增大了联盟链结构的去中心化程度,同时,由于参与信息确认的节点增多,区块链的安全程度也相应提高。
附图说明
图1是基于SM9算法的区块链隐私保护方案和系统总体架构示意图;
图2是区块链隐私保护方案和系统节点交易过程图;
图3是区块链隐私保护方案和系统交易信息结构图;
图4是系统链中区块主要结构图。
具体实施方式
下面结合附图和具体实施例对本发明做进一步详细的说明,但不以任何方式限制本发明的范围。
本发明采用一种区块链节点隐私保护方案,在联盟区块链环境下,构建了一种基于联盟链的隐私保护交易平台,可以实现对节点身份隐私的保护,保证区块生成合法性,同时减少联盟区块链中主要节点的工作权重,去中心化程度更高。设计的基于SM9算法的区块链隐私保护方案和系统总体架构如图1所示。
主要节点负责维护区块链参数与历史数据,进行区块链中所使用的SM9多KGC签名算法以及群签名算法的参数初始化,参与区块生成以及管理次要节点的加入与相关密钥的分发。
次要节点持有各自的签名密钥对与群签名密钥对,次要节点为群签名中的用户,次要节点之间可进行交易,完成区块链中点对点交易信息传递的流程。交易商定结束,需对信息进行群签名后进行广播,新区块将交易信息写入并由各个节点确认后即为生效。
本方案主要描述了节点交易流程,交易信息结构与链中区块主要结构,分别如图2,3,4所示。根据方案设计,节点交易过程具体操作步骤如下:
步骤A01.群管理员(Group Manager,GM)的身份为IDGM,则其需要向全部KGC申请建立群,KGC在核实GM身份后,将IDGM记录,以便之后KGC对新加入的节点成员生成并发放群私钥。申请群成功后,该群的公钥即为GM身份IDGM。群管理员的私钥则由签名算法生成并交由管理员GM保存。,进入步骤A02。
步骤A02.节点加入群后,KGC在验证节点合法之后,向节点成员发放签名私钥以及群私钥,交易进行时,发起方节点A需将与本次交易相关的上次交易信息的所属编号Num(TX0),与上次交易中,节点A所属的哈希值HashA(TX0),使用与上次交易相同的群签名要素P3(A)进行群签名后,结合本此交易的待交易信息UTXO0(B)(如货币数量等)进行签名,使用接受方节点B的身份为公钥进行加密并将信息传递给节点B,进入步骤A03。
步骤A03.节点B接受后,使用私钥进行解密,使用节点A的公钥验证签名,以及使用群身份进行群签名验证,全部通过并且核对本次交易的输入P3(A)与上次交易的输出P3(A)′是否一致,相同后确认交易信息,无误后组合Num(TX0),HashA(TX0)以及UTXO0(B),并计算其哈希值,作为所属自己的本次交易输出哈希值,并将此数据进行群签名,最终将结果签名,使用节点A公钥进行加密,返回节点A,进入步骤A04。
步骤A04.节点A解密验签通过后,进行交易信息的制作。广播的交易信息结构如图3所示,主要包括与本次交易关联的上次交易信息TX0以及本次交易的输出UTXO,将步骤A02中发送的数据写入本次交易的输入端,即为图3的TX0中,再将步骤A03中节点B返回的信息写入本次交易的输出端,即为图3的UTXO中,交易信息生成完毕后进行广播,TX0用于追溯上次交易的相关信息,并据此核对本次交易输入是否合理。UTXO主要包括各个输出所属的交易信息UTXO0以及输出哈希值与群签名,除了用于各个节点的确认之外,也作为下次交易输入的核对信息。主要节点接受广播的交易信息后,需要生成新区块,进入步骤A05。
步骤A05.主要节点在接受一段时间内的全部交易信息后,开始进行区块生成与并入。区块主要结构如图4所示,新生区块不仅需要记录全部TX,也需要记录上一个区块的编号Num(Block0)以及其哈希值Hash(Block0)来保证区块之间的关联性。同时,生成区块时,需要确定本区块的编号Num(Block)并计算本区块中全部数据的哈希值Hash(Block),将此四个数据组合,进行签名,最后发布,供各节点进行验证,进入步骤A06。
步骤A06.各节点在接受新区块时,需对其进行身份验证,确认其为主要节点生成,并且与最近一次生成的区块相关联后,再进行交易信息验证流程。各次要节点接收到交易信息后,需要首先验证其群签名是否有效,验证通过后,寻找与此交易输入关联的上一次的交易输出UTXO0,核对本次交易输入端的P3与上次交易输出端的P3′是否相同,若一致,则本次交易验证通过。当本次交易经过全部次要节点中半数以上验证通过后,才可并入新区块中。至此,节点A与B的交易确认有效。
本发明的签名算法采用SM9多KGC签名算法与一种基于SM9算法的群签名方案。方案需要进行参数初始化方法,所需运算方法与相关参数与SM9算法标准相同。定义了k个KGC,所有KGC首先商定随机数ks∈[1,N-1],并各自持有另一个随机数kej∈[1,N-1],其中j表示第j个KGC。每个KGC计算G2中元素Ppub-s=[ks]P2与Ppub-j=[kej]P2,之后依次计算直到j=k为止,使得则签名主密钥对为(ke,Ppub-s,Ppub-e),每个KGC秘密保存ks与自己持有的ke,公开Ppub-s与Ppub-e。次要节点A的标识为IDA,为了产生次要节点A的签名私钥dsA,KGC首先在有限域上计算t1=H1(IDA||hid,N)+ks,若t1不为0,则计算tj=kej·t1 -1mod N,然后将结果发送给次要节点A,最后次要节点A在本地计算得到自己的私钥。在群签名方案中,用户加入流程为:定义需要加入群的节点A,由GM核实次要节点A的身份IDA,核对通过后,将IDA通过权利要求2所述的SM9多KGC签名算法方案进行签名后,通过安全信道发送至KGC,KGC对GM的签名进行验证,完成后提取出IDA,商定ks∈[1,N-1],以及每个KGC各自持有kej∈[1,N-1],首先计算d1=[H1(IDGM||hid,N)+ks]1mod N,再根据IDA计算d2=[H1(IDA||hid,N)+ks]-1mod N,得出dsA′=[d2]P1,之后每个KGC计算dsAj=[kej]dsA′,次要节点A将每个KGC的dsAj相加即可得到签名私钥之后次要节点A选取随机数K∈[1,N-1],计算将结果重新发送给所有KGC,KGC重新计算一次,得发送给次要节点A,次要节点A最后运算可得到次要节点A的群私钥dsAG。至此次要节点A加入成功,其群密钥对为(dsA,dsAG,IDA,IDGM),其中dsA,dsAG为私钥,由A保存;IDGM为GM身份,亦为群签名的唯一标识。同时KGC需要保存用户的身份IDA。
SM9多KGC签名算法的签名生成过程为:定义消息为比特串M,则次要节点A若需要对其进行数字签名,则首先计算群GT中元素g=e(P1,Ppub-e),并选取随机数r∈[1,N-1],计算w=gr以及整数h=H2(M||w,N),之后计算整数l=(r-h)mod N,若l为0,则重新选取随机数,l不为0时则最后计算S=[l]dsA,可得到关于消息M的签名(h,S)。验证过程为:定义验证者为次要节点B,其接收到的消息M′的签名为(h′,S′),如需要验证签名,则需要首先验证h′∈[1,N-1]以及S′∈G1,若均成立,则计算群GT中的元素g=e(P1,Ppub-e),再计算群GT中的元素t=gh′与整数h1=H1(IDA||hid,N),之后计算群G2中的元素P=[h1]P2+Ppub-s与群GT中的元素u=e(S′,P),再计算群GT中的元素w′=u·t,最后计算h2=H2(M′||w′,N)并与h′进行比较,若一致,则验证通过。
基于SM9的群签名方案的签名生成过程为:定义群中次要节点A,其要对消息M进行群签名,则其需要首先计算g=e(P1,Ppub-e),并秘密选取随机数r1∈[1,N-1]与r2∈[1,N-1],计算之后计算h=H2(M||w,N),计算S1=(r1 -1)·(r1-h)·dsA与S2=(r2 -1)(r1-h)·dsAG,最后计算h1=H1(IDA||hid,N),P3′=[h1]P2+Ppub-s,P3=[r2]P3′得出次要节点A对消息M的群签名(h,P3,S1,S2)。验证过程为:定义群中次要节点B,接收到的消息M′与其群签名(h′,P3′,S1′,S2′),群中次要节点B若想验证其是否属于群IDGM,则需要首先计算h1=H1(IDGM||hid,N),接着计算P=[h1]P2+Ppub-s,之后计算u1=e(S2,P)与u2=e(S1,Ppub-e),若u1≠u2则验证不通过,否则继续计算u=e(S1,P3),g=e(P1,Ppub-e)与t=gW,最终计算w′=u·t,得到h=H2(M′||w′N),对比h′与h,一致则验证通过,至此可证明该消息由群IDGM中某个成员所签名。
Claims (9)
1.一种基于SM9算法的区块链隐私保护方案和系统,其特征在于,提供了一种基于联盟链的隐私保护交易平台,描述了节点间交易以及区块生成与验证流程,包括如下步骤:
定义了基于区块链技术的点对点交易与区块信息验证平台,在联盟区块链环境下提供了一种由主要节点、次要节点构成的交易隐私保护架构设计。
a)主要节点负责维护区块链参数与历史数据,进行区块链中所使用的SM9多KGC签名算法以及群签名算法的参数初始化,参与区块生成以及管理次要节点的加入与相关密钥的分发。
b)次要节点持有各自的签名密钥对与群签名密钥对,次要节点为群签名中的用户,次要节点之间可进行交易,完成区块链中点对点交易信息传递的流程。交易商定结束,需对信息进行群签名后进行广播,新区块将交易信息写入并由各个节点确认后即为生效。
步骤001.群管理员(Group Manager,GM)的身份为IDGM,则其需要向全部KGC申请建立群,KGC在核实GM身份后,将IDGM记录,以便之后KGC对新加入的节点成员生成并发放群私钥。申请群成功后,进入步骤002。
步骤002.节点加入群后,KGC在验证节点合法之后,向节点成员发放签名私钥以及群私钥,节点接收私钥后,可与其他节点进行交易。发起方节点A将交易信息进行签名与群签名后,加密传递给节点B,进入步骤003。
步骤003.节点B接受后进行解密,使用节点A的公钥验证签名,以及使用群身份进行群签名验证,全部通过并且核对本次交易的发起方与上次交易的接受方是否一致,相同后确认交易信息,无误后并将此数据进行群签名,最终将结果签名,加密返回节点A,进入步骤004。
步骤004.节点A解密验签通过后,将交易信息进行广播,主要节点接受广播的交易信息后,生成新区块,进入步骤005。
步骤005.各节点在接受新区块时,需对其进行身份验证,确认其为主要节点生成,并且与最近一次生成的区块相关联后,再进行交易信息验证流程。当本次交易经过全部次要节点中半数以上验证通过后,才可并入新区块中。至此,节点A与B的交易确认有效。
2.根据权利要求1所述基于SM9算法的区块链隐私保护方案和系统,其特征在于,提供了一种SM9多KGC签名算法以及群签名算法方案,方案需要进行参数初始化方法,所需运算方法与相关参数与SM9算法标准相同。定义了k个KGC,所有KGC首先商定随机数ks∈[1,N-1],并各自持有另一个随机数kej∈[1,N-1],其中j表示第j个KGC。每个KGC计算G2中元素Ppub-s=[ks]P2与Ppub-j=[kej]P2,之后依次计算直到j=k为止,使得则签名主密钥对为(ke,Ppub-s,Ppub-e),每个KGC秘密保存ks与自己持有的ke,公开Ppub-s与Ppub-e。次要节点A的标识为IDA,为了产生次要节点A的签名私钥dsA,KGC首先在有限域上计算t1=H1(IDA||hid,N)+ks,若t1不为0,则计算tj=kej·t1 -1mod N,然后将结果发送给次要节点A,最后次要节点A在本地计算得到自己的私钥。
3.根据权利要求2所述SM9多KGC签名算法方案,其特征在于,提供了一种SM9多KGC签名生成方法:定义消息为比特串M,则次要节点A若需要对其进行数字签名,则首先计算群GT中元素g=e(P1,Ppub-e),并选取随机数r∈[1,N-1],计算w=gr以及整数h=H2(M||w,N),之后计算整数l=(r-h)mod N,若l为0,则重新选取随机数,l不为0时则最后计算S=[l]dsA,可得到关于消息M的签名(h,S)。
4.根据权利要求2所述SM9多KGC签名算法方案,其特征在于,提供了一种SM9多KGC签名验证方法:定义验证者为次要节点B,其接收到的消息M′的签名为(h′,S′),如需要验证签名,则需要首先验证h′∈[1,N-1]以及S′∈G1,若均成立,则计算群GT中的元素g=e(P1,Ppub-e),再计算群GT中的元素t=gh′与整数h1=H1(IDA||hid,N),之后计算群G2中的元素P=[h1]P2+Ppub-s与群GT中的元素u=e(S′,P),再计算群GT中的元素w′=u·t,最后计算h2=H2(M′||w′,N)并与h′进行比较,若一致,则验证通过。
5.根据权利要求2所述基于SM9的群签名算法方案,其特征在于,提供了一种基于SM9的群签名用户加入方法:定义需要加入群的节点A,由GM核实次要节点A的身份IDA,核对通过后,将IDA通过权利要求2所述的SM9多KGC签名算法方案进行签名后,通过安全信道发送至KGC,KGC对GM的签名进行验证,完成后提取出IDA,商定ks∈[1,N-1],以及每个KGC各自持有kei∈[1,N-1],首先计算d1=[H1(IDGM||hid,N)+ks]-1mod N,再根据IDA计算d2=[H1(IDA||hid,N)+ks]-1mod N,得出dsA′=[d2]P1,之后每个KGC计算dsAj=[kej]dsA′,次要节点A将每个KGC的dsAj相加即可得到签名私钥之后次要节点A选取随机数K∈[1,N-1],计算将结果重新发送给所有KGC,KGC重新计算一次,得发送给次要节点A,次要节点A最后运算可得到次要节点A的群私钥dsAG。至此次要节点A加入成功,其群密钥对为(dsA,dsAG,IDA,IDGM),其中dsA,dsAG为私钥,由A保存;IDGM为GM身份,亦为群签名的唯一标识。同时KGC需要保存用户的身份IDA。
6.根据权利要求2所述基于SM9的群签名算法方案,其特征在于,提供了一种基于SM9的群签名生成方法:定义群中次要节点A,其要对消息M进行群签名,则其需要首先计算g=e(P1,Ppub-e),并秘密选取随机数r1∈[1,N-1]与r2∈[1,N-1],计算之后计算h=H2(M||w,N),计算S1=(r2 -1)·(r1-h)·dsA与S2=(r2 -1)(r1-h)·dsAG,最后计算h1=H1(IDA||hid,N),P3′=[h1]P2+Ppub-s,P3=[r2]P3′得出次要节点A对消息M的群签名(h,P3,S1,S2)。
7.根据权利要求2所述基于SM9的群签名算法方案,其特征在于,提供了一种基于SM9的群签名验证方法:定义群中次要节点B,接收到的消息M′与其群签名(h′,P3′,S1′,S2′),群中次要节点B若想验证其是否属于群IDGM,则需要首先计算h1=H1(IDGM||hid,N),接着计算P=[h1]P2+Ppub s,之后计算u1=e(S2,P)与u2=e(S1,Ppub-e),若u1≠u2则验证不通过,否则继续计算u=e(S1,P3),g=e(P1,Ppub e)与t=gh′,最终计算w′=u·t,得到h=H2(M′||w′,N),对比h′与h,一致则验证通过,至此可证明该消息由群IDGM中某个成员所签名。
8.根据权利要求1所述基于SM9算法的区块链隐私保护方案和系统,其特征在于,提供了一种广播交易信息构成方法:广播的交易信息主要包括与本次交易关联的上次交易信息TX0以及本次交易的输出UTXO。TX0用于追溯上次交易的相关信息,并据此核对本次交易输入是否合理。UTXO主要包括各个输出所属的交易信息UTXO0以及输出哈希值与群签名,除了用于各个节点的确认之外,也作为下次交易输入的核对信息。
9.根据权利要求1所述基于SM9算法的区块链隐私保护方案和系统,其特征在于,提供了一种新生区块构成方法:新生区块需要记录上一个区块的编号Num(Block0)以及其哈希值Hash(Block0)来保证区块之间的关联性。同时,生成区块时,需要确定本区块的编号Num(Block)并计算本区块中全部数据的哈希值Hash(Block),将此四个数据组合,进行签名,最后发布。
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN201811245996.7A CN109409884A (zh) | 2018-10-25 | 2018-10-25 | 一种基于sm9算法的区块链隐私保护方案和系统 |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
CN201811245996.7A CN109409884A (zh) | 2018-10-25 | 2018-10-25 | 一种基于sm9算法的区块链隐私保护方案和系统 |
Publications (1)
Publication Number | Publication Date |
---|---|
CN109409884A true CN109409884A (zh) | 2019-03-01 |
Family
ID=65469023
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
CN201811245996.7A Pending CN109409884A (zh) | 2018-10-25 | 2018-10-25 | 一种基于sm9算法的区块链隐私保护方案和系统 |
Country Status (1)
Country | Link |
---|---|
CN (1) | CN109409884A (zh) |
Cited By (13)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN110149633A (zh) * | 2019-05-16 | 2019-08-20 | 桂林电子科技大学 | 一种支持批验证的安全多方认证方法及系统 |
CN110247757A (zh) * | 2019-04-19 | 2019-09-17 | 中国工商银行股份有限公司 | 基于国密算法的区块链处理方法、装置及系统 |
CN110309663A (zh) * | 2019-06-25 | 2019-10-08 | 湖南搜云网络科技股份有限公司 | 基于区块链的隐私认证方法及系统 |
CN110544101A (zh) * | 2019-09-10 | 2019-12-06 | 苏州阿尔山数字科技有限公司 | 基于sm9的联盟链身份认证方法 |
CN110768781A (zh) * | 2019-08-28 | 2020-02-07 | 如般量子科技有限公司 | 基于联盟链且抗量子计算的公私钥颁发方法及系统 |
CN110781140A (zh) * | 2019-09-06 | 2020-02-11 | 平安科技(深圳)有限公司 | 区块链中数据签名的方法、装置、计算机设备及存储介质 |
CN110784488A (zh) * | 2019-11-07 | 2020-02-11 | 深圳职业技术学院 | 一种可控匿名的区块链系统 |
CN111767557A (zh) * | 2020-06-22 | 2020-10-13 | 重庆渝抗医药科技有限公司 | 基于区块链的数据加密工作方法 |
CN112291059A (zh) * | 2020-07-28 | 2021-01-29 | 北京金山云网络技术有限公司 | 密钥生成方法及装置、存储介质及电子设备 |
CN113159766A (zh) * | 2021-04-13 | 2021-07-23 | 浙江数链科技有限公司 | 数据保护方法、装置、系统、电子装置和存储介质 |
WO2021239072A1 (zh) * | 2020-05-28 | 2021-12-02 | 支付宝(杭州)信息技术有限公司 | 在联盟链网络中创建节点组、基于节点组的交易方法 |
CN115442050A (zh) * | 2022-08-29 | 2022-12-06 | 成都安恒信息技术有限公司 | 一种基于sm9算法的隐私保护的联邦学习方法 |
CN115589303A (zh) * | 2022-07-11 | 2023-01-10 | 昆明理工大学 | 基于sm9算法和跨链技术的数据共享与隐私保护方法 |
-
2018
- 2018-10-25 CN CN201811245996.7A patent/CN109409884A/zh active Pending
Cited By (21)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN110247757A (zh) * | 2019-04-19 | 2019-09-17 | 中国工商银行股份有限公司 | 基于国密算法的区块链处理方法、装置及系统 |
CN110149633A (zh) * | 2019-05-16 | 2019-08-20 | 桂林电子科技大学 | 一种支持批验证的安全多方认证方法及系统 |
CN110309663A (zh) * | 2019-06-25 | 2019-10-08 | 湖南搜云网络科技股份有限公司 | 基于区块链的隐私认证方法及系统 |
CN110309663B (zh) * | 2019-06-25 | 2023-03-03 | 湖南搜云网络科技股份有限公司 | 基于区块链的隐私认证方法及系统 |
CN110768781B (zh) * | 2019-08-28 | 2021-10-22 | 如般量子科技有限公司 | 基于联盟链且抗量子计算的公私钥颁发方法及系统 |
CN110768781A (zh) * | 2019-08-28 | 2020-02-07 | 如般量子科技有限公司 | 基于联盟链且抗量子计算的公私钥颁发方法及系统 |
CN110781140A (zh) * | 2019-09-06 | 2020-02-11 | 平安科技(深圳)有限公司 | 区块链中数据签名的方法、装置、计算机设备及存储介质 |
CN110781140B (zh) * | 2019-09-06 | 2023-08-18 | 平安科技(深圳)有限公司 | 区块链中数据签名的方法、装置、计算机设备及存储介质 |
CN110544101A (zh) * | 2019-09-10 | 2019-12-06 | 苏州阿尔山数字科技有限公司 | 基于sm9的联盟链身份认证方法 |
CN110784488A (zh) * | 2019-11-07 | 2020-02-11 | 深圳职业技术学院 | 一种可控匿名的区块链系统 |
CN110784488B (zh) * | 2019-11-07 | 2021-10-19 | 深圳职业技术学院 | 一种可控匿名的区块链系统 |
WO2021239072A1 (zh) * | 2020-05-28 | 2021-12-02 | 支付宝(杭州)信息技术有限公司 | 在联盟链网络中创建节点组、基于节点组的交易方法 |
CN111767557B (zh) * | 2020-06-22 | 2021-07-30 | 王仁义 | 基于区块链的数据加密工作方法 |
CN111767557A (zh) * | 2020-06-22 | 2020-10-13 | 重庆渝抗医药科技有限公司 | 基于区块链的数据加密工作方法 |
CN112291059B (zh) * | 2020-07-28 | 2022-10-21 | 北京金山云网络技术有限公司 | 密钥生成方法及装置、存储介质及电子设备 |
CN112291059A (zh) * | 2020-07-28 | 2021-01-29 | 北京金山云网络技术有限公司 | 密钥生成方法及装置、存储介质及电子设备 |
CN113159766A (zh) * | 2021-04-13 | 2021-07-23 | 浙江数链科技有限公司 | 数据保护方法、装置、系统、电子装置和存储介质 |
CN115589303A (zh) * | 2022-07-11 | 2023-01-10 | 昆明理工大学 | 基于sm9算法和跨链技术的数据共享与隐私保护方法 |
CN115589303B (zh) * | 2022-07-11 | 2024-02-27 | 昆明理工大学 | 基于sm9算法和跨链技术的数据共享与隐私保护方法 |
CN115442050A (zh) * | 2022-08-29 | 2022-12-06 | 成都安恒信息技术有限公司 | 一种基于sm9算法的隐私保护的联邦学习方法 |
CN115442050B (zh) * | 2022-08-29 | 2024-08-06 | 成都安恒信息技术有限公司 | 一种基于sm9算法的隐私保护的联邦学习方法 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
CN109409884A (zh) | 一种基于sm9算法的区块链隐私保护方案和系统 | |
US10666428B2 (en) | Efficient methods for protecting identity in authenticated transmissions | |
CN108270571B (zh) | 基于区块链的物联网身份认证系统及其方法 | |
CN111654363B (zh) | 一种基于群签名和同态加密的联盟链隐私保护方法 | |
WO2021042685A1 (zh) | 一种区块链的交易方法、装置及系统 | |
CN109495274B (zh) | 一种去中心化智能锁电子钥匙分发方法及系统 | |
CN111092717B (zh) | 智能家居环境下基于组认证安全可靠的通信方法 | |
CN102594558B (zh) | 一种可信计算环境的匿名数字证书系统及验证方法 | |
CN108199835B (zh) | 一种多方联合私钥解密方法 | |
AU2003202511B2 (en) | Methods for authenticating potential members invited to join a group | |
CN109687965B (zh) | 一种保护网络中用户身份信息的实名认证方法 | |
CN114730420A (zh) | 用于生成签名的系统和方法 | |
US20050152542A1 (en) | Public key encryption for groups | |
JPH10510692A (ja) | ユーザコンピュータユニットuとネットワークコンピュータユニットnの間における暗号鍵のコンピュータ支援交換方法 | |
CN106301788A (zh) | 一种支持用户身份认证的群组密钥管理方法 | |
JP2002534701A (ja) | 寄託されない署名専用キーを用いた自動回復可能な自動可能暗号システム | |
CN113761582A (zh) | 基于群签名的可监管区块链交易隐私保护方法及系统 | |
CN114036539A (zh) | 基于区块链的安全可审计物联网数据共享系统及方法 | |
CN113468570A (zh) | 基于智能合约的隐私数据共享方法 | |
CN103905384A (zh) | 基于安全数字证书的嵌入式终端间会话握手的实现方法 | |
CN102769623A (zh) | 基于数字证书和生物识别信息进行双重认证的方法 | |
CN114666032B (zh) | 基于同态加密的区块链交易数据隐私保护方法 | |
CN107612680A (zh) | 一种移动网络支付中的国密算法 | |
CN111416712B (zh) | 基于多个移动设备的量子保密通信身份认证系统及方法 | |
CN115396096A (zh) | 基于国密算法的秘密文件的加、解密方法及保护系统 |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
PB01 | Publication | ||
PB01 | Publication | ||
WD01 | Invention patent application deemed withdrawn after publication |
Application publication date: 20190301 |
|
WD01 | Invention patent application deemed withdrawn after publication |