CN102291396B - 可信平台远程证明的匿名认证算法 - Google Patents

可信平台远程证明的匿名认证算法 Download PDF

Info

Publication number
CN102291396B
CN102291396B CN201110218652.9A CN201110218652A CN102291396B CN 102291396 B CN102291396 B CN 102291396B CN 201110218652 A CN201110218652 A CN 201110218652A CN 102291396 B CN102291396 B CN 102291396B
Authority
CN
China
Prior art keywords
platform
authentication
transmit leg
credible
sequence
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.)
Active
Application number
CN201110218652.9A
Other languages
English (en)
Other versions
CN102291396A (zh
Inventor
李海建
程宏峰
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
HANGZHOU SUNYARD DIGITAL TECHNOLOGY Co Ltd
Original Assignee
HANGZHOU SUNYARD DIGITAL TECHNOLOGY Co Ltd
Priority date (The priority date 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 date listed.)
Filing date
Publication date
Application filed by HANGZHOU SUNYARD DIGITAL TECHNOLOGY Co Ltd filed Critical HANGZHOU SUNYARD DIGITAL TECHNOLOGY Co Ltd
Priority to CN201110218652.9A priority Critical patent/CN102291396B/zh
Publication of CN102291396A publication Critical patent/CN102291396A/zh
Application granted granted Critical
Publication of CN102291396B publication Critical patent/CN102291396B/zh
Active legal-status Critical Current
Anticipated expiration legal-status Critical

Links

Abstract

本发明提供一种可信平台远程证明的匿名认证算法,采用本发明所述方法,匿名性好,并且既验证了发送方的身份信息,又保障了发送方的隐私信息,而且采用的幂指计算,其计算次数为常数,减少了加密、解密运算的次数,不会随着签名环的规模增大影响方案效率,具有相对来说可信平台能够接受的算法复杂度,综上,基本可以满足可信平台之间直接、匿名的身份验证。

Description

可信平台远程证明的匿名认证算法
技术领域:
本发明涉及信息安全领域,具体讲是一种可信平台远程证明的匿名认证算法。
背景技术:
远程证明是可信计算的基本特征之一。可信计算可以通过远程证明实现对接入终端的安全性检验。按照可信计算组织(Trusted Computing Group)提出的规范文档,服务端通过检测远程计算机平台的完整性实现证明从而确定信任。但服务端在进行安全检测时,接入终端必须提供平台的各种配置信息,这样很容易侵犯到终端用户的隐私。出于这一点的考虑,可信计算组织引入了身份验证密钥AIK(Attestation Identity Keys)来保护可信平台模块的签名密钥EK(Endorsement Key)从而隐藏平台的身份信息。AIK的引入保护了可信平台内部的EK身份安全,但是仍没有考虑平台配置信息的隐私暴露问题。
目前现有的解决方案大致有如下两种:基于第三方认证模型和零知识证明。
基于第三方认证模型具体实施过程如下:
(1)首先建立一个安全中心,安全中心掌握所有合法的可信平台密钥。
(2)当一个可信平台需要向另一方证明自己的可信性与真实性时,就产生AIK密钥对,并将之发送给安全中心。
(3)安全中心在密钥列表中查询是否有需要的签名密钥,若有,则在AIK上发放证书,并使用EK加密。
(4)只有可信平台拥有正确的EK私钥,才可以解密出安全中心发放的证书,从而用证书证明自己。
第三方认证模型存在两个明显的缺点和不足。首先,它难以避免恶意攻击者发起的拒绝服务攻击。出于安全角度考虑,可信平台每次需要证明自己身份时,都不得不重新向安全中心发起AIK认证申请。因此,安全中心不能拒绝短时间内的连续认证请求,而如果有攻击者连续发送大量垃圾AIK证书申请时,就会造成安全中心无法正常工作。并且,第三方认证模型还有一个难题,就是安全中心的运营问题。对于用户来说,安全中心不能由服务提供商运营,否则个人隐私难以得到保证;对于服务提供商而言,安全中心不能由用户运营,否则合法身份不能得到认证。
而另一种解决方案零知识证明,则是基于了Camenisch-Lysyanskaya签名方案,吸收了群签名、身份托管等技术的优点,在实现验证用户身份的同时,又保护了用户隐私,其根本思想是运用了零知识证明(Zero Knowledge Proof)。在零知识证明中,一个人无需揭开某个秘密也可以向其他人证明自己知道这个秘密,其具体实施步骤如下:
(1)、发行商公布其公钥n,a,b,d,其中n是RSA算法的模数,a、b、c为信息上的签名。满足:ce=axbsd mod n;
(2)、可信平台模块签署公钥DAA=ax mod n,x是可信平台模块的密钥;
(3)、可信平台模块取随机数s′,计算c′=cbs′mod n,将c′发送给验证方;
(4)、验证方计算s+es′=s″,并代入d=c′ea-xb-s′mod n,如果等式成立,则说明可信平台模块掌握c,e,s″的内容,即请求方存在可信平台,是安全的,否则,平台身份不安全。
这种零知识证明认证方案很好的满足了可信计算的认证要求以及用户信息的保密要求,但由于其计算过程相当复杂,有大量的模幂运算,并且涉及到很多远超1024位的大数运算,然而,可信平台模块资源有限、计算能力有限,一般只能支持最高到1024×1024的计算。即使采用一些加速签名或解密的算法,也依然很难将大数全部降到1024位以下,就目前的技术水平来看,在可信平台模块硬件芯片没有突破发展的情况下,基于零知识认证的方案几乎难以实现。
综上所述,目前现有的认证技术都难以满足可信平台之间的匿名认证要求。
发明内容:
本发明要解决的一个技术问题是,克服现有技术的缺陷,提供一种算法复杂度较低,能够满足可信平台之间的匿名认证要求的可信平台远程证明的匿名认证算法。
本发明的技术解决方案是,提供一种可信平台远程证明的匿名认证算法,它包括以下步骤:
(1)、参数初始化:涉及验证双方的可信平台选择两个互异的大素数PR1、PR2,设定参数nA=PR1PR2,eA=(PR1-1)(PR2-1),设定公共参数gA,gA为不超过nA的正整数,同时通过可信平台的密钥生成器及参数eA生成公私钥对(eA,dA),其中eA为私钥,dA为生成的公钥,设定安全单向累加器H,随机序列X(x1,x2...xs-1,xs+1...,xt),其中x1,x2...xs-1,xs+1....xt为数值或字符,抗碰撞散列函数h;
(2)、发送方平台选择任意t-1个可信平台的公钥,与自身的公钥ps构成公钥序列{p1,p2.......pt},其中t为匿名等级参数,由发送方平台自行设定t的值;
(3)、选择抗碰撞散列函数h,令h={0,1}→{0,1}I,I=rd,其中r为指定散列化后的比特数,d为块长,l为序列长度,计算yi=h(xi),i≠s,得出序列Y1(y1,y2...ys-1,ys+1....yt);
(4)、将序列Y1中的yi按每d位一组,划分为r组,得yi1,yi2...yir,逐个计算
Figure BDA0000080342580000031
上述公式是指将yij与值为0、长度为d的比特块做异或运算,若其结果不为零,则将之置为1,反之则为0,重新计算 y i = y i 1 * 2 r - 1 + y i 2 * 2 r - 2 + . . . . . . + y ir * 2 0 = Σ j = 1 r y ij * 2 r - i , 获得散列后位长为r的序列Y2(y1,y2...ys-1,ys+1....yt),
Figure BDA0000080342580000034
为逐比特异或运算;
(5)、发送方平台由密钥生成器生成一个身份验证密钥,记为δ,并选择一个私有信息sA,计算yA=(gA ),xA=(gA sA)δ,则待发送的签名信息m=(nA,eA,yA,xA);
(6)、选择一个环签名函数,并将序列Y2带入环签名方程ck(y1,.......yn,m)=v,v为数字签名,k为对称加密算法,k=H(p1,p2,...pt),其对应的验证方程σ=vf(p1,p2,...pt;m,v);
(7)、发送方平台发送验证方程σ、数字签名v和签名信息m=(nA,eA,yA,,xA)到验证方平台,开始验证;
(8)、验证方平台在接收到发送方平台发送的签名信息m和验证方程σ、数字签名v之后,首先验证身份的合法性,若身份非法,则拒绝请求,若合法,则进行下一步骤;
(9)、验证方平台随机选择一个私有信息sB,并计算k1=(xA)sBmod nA,同时返回eA(sB)给发送方平台;
(10)、发送方平台在接收到验证方平台的返回信息之后,计k2=(δdA(eA(sB))+sA))sB并返回计算结果k2给验证方平台;
(11)、验证方平台接收到发送方平台返回的k2,计算k3=(gA k2yA sB)sB mod nA与k1比较,yA=(gA ),如果k1=k3,则表明发送方平台拥有可信平台模块的密钥,反之则判定发送方平台无法提供由可信平台模块产生的身份认证密钥。
采用本发明所述的可信平台远程证明的匿名认证算法,具有以下优点:
本发明所述的可信平台远程证明的匿名认证算法,
发送方采用环签名的方法进行身份认证密钥的生成,在环签名的生成过程中,因为x1,x2...xs-1,xs+1...xt序列是随机选择的,因而yi=h(xi),i≠s,得到得y1,y2...ys-1,ys+1....yt也是随机的,由于签名环内的任意一个成员都可以生成这样的签名,因此除了签名发起人之外,任何人都无法确定真正的签名者。就算存在攻击者非法获取了所有签名环内的成员的私钥信息,也依然难以确定签名人,其理论概率不超过1/n,n为环内成员的个数,因此匿名性好。
发送方需要向验证方证明自身可信,就需要出示相关信息,但同时为了保护发送方隐私,将信息验证转化为等式验证,k1与k3实际为参数不同但结果相同的算式,发送方提供的签名信息经过验证方处理之后返回给发送方,只有发送方确实掌握可信平台模块,才能解出与验证方相同的结果,而验证方只需比较发送方是否能计算出正确结果即可,既验证了发送方的身份信息,又保障了发送方的隐私信息。
本发明中采用的幂指计算,其计算次数为常数,减少了加密、解密运算的次数,不会随着签名环的规模增大影响方案效率,具有相对来说可信平台能够接受的算法复杂度,基本可以满足可信平台之间直接、匿名的身份验证。
具体实施方式:
下面结合具体实施方式对本发明作进一步详细的说明。
本发明提供一种可信平台远程证明的匿名认证算法,本算法基于公钥加密体系理论假设RSA Assumption,由于公钥加密体系理论假设为信息安全领域内公知技术,故不再赘述,本发明包括以下步骤:
(1)、参数初始化:涉及验证双方的可信平台选择两个互异的大素数PR1、PR2,设定参数nA=PR1PR2,eA=(PR1-1)(PR2-1),设定公共参数gA,gA为不超过nA的正整数,同时通过可信平台的密钥生成器及参数eA生成公私钥对(eA,dA),其中eA为私钥,dA为生成的公钥,设定安全单向累加器H,随机序列X(x1,x2...xs-1,xs+1...,xt),其中x1,x2...xs-1,xs+1....xt为数值或字符,抗碰撞散列函数h;
(2)、发送方平台选择任意t-1个可信平台的公钥,与自身的公钥ps构成公钥序列{p1,p2.......pt},其中t为匿名等级参数,由发送方平台自行设定t的值,t越大匿名等级越高,但是计算的复杂度越高,t越小,匿名等级越低,但是计算的复杂程度也越低,发送方平台可根据需求自行设定;
(3)、选择抗碰撞散列函数h,令h={0,1}→{0,1}I,上述公式是指任意长度的比特块由函数h处理后将转化为定长为l的比特块,I=rd,其中r为指定散列化后的比特数,d为块长,l为序列长度,计算yi=h(xi),i≠s,得出序列Y1(y1,y2...ys-1,ys+1....yt);
(4)、将序列Y1中的yi按每d位一组,划分为r组,得yi1,yi2...yir,逐个计算
Figure BDA0000080342580000051
Figure BDA0000080342580000052
上述公式是指将yij与值为0、长度为d的比特块做异或运算,若其结果不为零,则将之置为1,反之则为0,重新计算 y i = y i 1 * 2 r - 1 + y i 2 * 2 r - 2 + . . . . . . + y ir * 2 0 = Σ j = 1 r y ij * 2 r - i , 获得散列后位长为r的序列Y2(y1,y2...ys-1,ys+1....yt),
Figure BDA0000080342580000054
为逐比特异或运算;
(5)、发送方平台由密钥生成器生成一个身份验证密钥,记为δ,并选择一个私有信息sA,计算yA=(gA ),xA=(gA sA)δ,则待发送的签名信息m=(nA,eA,yA,xA);
(6)、选择一个环签名函数,并将序列Y2带入环签名方程ck(y1,.......yn,m)=v,v为数字签名,k为对称加密算法,k=H(p1,p2,...pt),其对应的验证方程σ=vf(p1,p2,...pt;m,v);
(7)、发送方平台发送验证方程σ、数字签名v和签名信息m=(nA,eA,yA,,xA)到验证方平台,开始验证;验证时将步骤(2)中的公钥序列带入,同时输入签名信息m和数字签名v,若该签名信息m的数字签名v确实由该环签名产生,则带入验证方程返回true,否则返回false;验证方法为目前常规验证方法,故不再详述;
(8)、验证方平台在接收到发送方平台发送的签名信息m和验证方程σ、数字签名v之后,首先验证身份的合法性,若身份非法,则拒绝请求,若合法,则进行下一步骤;
(9)、验证方平台随机选择一个私有信息sB,并计算k1=(xA)sBmod nA,同时返回eA(sB)给发送方平台;eA(sB)是指将采用私钥eA对sB进行加密;
(10)、发送方平台在接收到验证方平台的返回信息之后,计k2=(δdA(eA(sB))+sA))sB并返回计算结果k2给验证方平台;
(11)、验证方平台接收到发送方平台返回的k2,计算k3=(gA k2yA sB)sB mod nA与k1比较,yA=(gA ),将yA带入到k3式子中即可得出k3=(gA k2yA sB)sB mod nA=(gA sBδ+sAgA -sA)sB mod nA=(gA sA)δ)sB mod nA=((xA)sB mod nA=k1,因此如果k1=k3,则表明发送方平台拥有可信平台模块的密钥,反之则判定发送方平台无法提供由可信平台模块产生的身份认证密钥。
上述过程中可信平台远程证明的匿名认证算法进行三次交互验证完身份信息的核对,分别为发送方平台发送身份数字签名v,方程σ和签名信息m到验证方平台,验证方返回eA(gA sB)给发送方平台,发送方返回计算结果k2给验证方平台,安全程度高。接下来,就本方案的匿名性、不可伪造性题展开分析论证,如下:
第一、在环签名的生成过程中,因为x1,x2...xs-1,xs+1....xt序列是随机选择的,因而yi=h(xi),i≠s,得到的y1,y2...ys-1,ys+1....yt也是随机的,由于签名环内的任意一个成员都可以生成这样的签名,因此除签名发起人之外,任何人都无法确定真正的签名者。就算存在攻击者非法获取了所有环内成员的私钥信息,也依然难以确定签名人,其理论概率不超过1/n,这里的n为环内成员的个数。
第二、通过反证法,可以证明上述匿名认证算法是不可伪造的。假设有一个攻击者成功攻破了本认证方案,换言之,攻击者有能力伪造签名者的身份验证密钥信息,也就是攻击者利用签名消息m=(nA,eA,yA,xA)根据yA=(gA ),xA=(gA sA)δ,eA(sB)和k2=(δdA(eA(sB))+sA))sB计算并得出了δ的值,那么攻击者也就解决了分解gA,nA这两个大数,这与我们的前提条件,即公钥加密体系理论假设矛盾,因此假设不成立,不可伪造性得证。

Claims (1)

1.一种可信平台远程证明的匿名认证算法,其特征在于:它包括以下步骤: 
(1)、参数初始化:涉及验证双方的可信平台选择两个互异的大素数PR1、PR2,设定参数nA=PR1PR2,eA=(PR1-1)(PR2-1),设定公共参数gA,gA为不超过nA的正整数,同时通过可信平台的密钥生成器及参数eA生成公私钥对(eA,dA),其中eA为私钥,dA为生成的公钥,设定安全单向累加器H,随机序列X(x1,x2…xs-1,xs+1…,xt),其中x1,x2…xs-1,xs+1… - ,xt为数值或字符,抗碰撞散列函数h; 
(2)、发送方平台选择任意t-1个可信平台的公钥,与自身的公钥ps构成公钥序列{p1,p2…… - ,pt},其中t为匿名等级参数,由发送方平台自行设定t的值; 
(3)、选择抗碰撞散列函数h,令h={0,1}*→{0,1}l,l=rd,其中r为指定散列化后的比特数,d为块长,l为序列长度,计算yi=h(xi),i≠s,得出序列Y1(y1,y2…ys-1,ys+1…,yt); 
(4)、将序列Y1中的yi按每d位一组,划分为r组,得yi1,yi2…yir,逐个计算
Figure FDA0000371766750000013
Figure FDA0000371766750000014
,上述公式是指将yij与值为0、长度为d的比特块做异或运算,若其结果不为零,则将之置为1,反之则为0,重新计算
Figure FDA0000371766750000011
获得散列后位长为r的序列Y2(y1,y2…ys-1,ys+1… ,yt),为逐比特异或运算; 
(5)、发送方平台由密钥生成器生成一个身份验证密钥,记为δ,并选择一个私有信息sA,计算yA=(gA ),xA=(gA sA)δ,则待发送的签名信息m=(nA,eA,yA,xA); 
(6)、选择一个环签名函数,并将序列Y2带入环签名方程ck(y1,…… ,yn,m)=v,v为数字签名,k为对称加密算法,k=H(p1,p2,…pt),其对应的验证方程σ=vf(p1,p2,…pt;m,v); 
(7)、发送方平台发送验证方程σ、数字签名v和签名信息m=(nA,eA,yA, xA)到验证方平台,开始验证; 
(8)、验证方平台在接收到发送方平台发送的签名信息m和验证方程σ、数字签名v之后,首先验证身份的合法性,若身份非法,则拒绝请求,若合法,则进行下一步骤; 
(9)、验证方平台随机选择一个私有信息sB,并计算k1=(xA)sBmodnA,同时返回eA(sB)给发送方平台; 
(10)、发送方平台在接收到验证方平台的返回信息之后,计k2=(δdA(eA(sB))+sA))sB并返回计算结果k2给验证方平台; 
(11)、验证方平台接收到发送方平台返回的k2,计算k3=(gA k2yA sB)sBmodnA与k1比较,yA=(gA ),如果k1=k3,则表明发送方平台拥有可信平台模块的密钥,反之则判定发送方平台无法提供由可信平台模块产生的身份认证密钥。 
CN201110218652.9A 2011-08-01 2011-08-01 可信平台远程证明的匿名认证算法 Active CN102291396B (zh)

Priority Applications (1)

Application Number Priority Date Filing Date Title
CN201110218652.9A CN102291396B (zh) 2011-08-01 2011-08-01 可信平台远程证明的匿名认证算法

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
CN201110218652.9A CN102291396B (zh) 2011-08-01 2011-08-01 可信平台远程证明的匿名认证算法

Publications (2)

Publication Number Publication Date
CN102291396A CN102291396A (zh) 2011-12-21
CN102291396B true CN102291396B (zh) 2014-01-29

Family

ID=45337504

Family Applications (1)

Application Number Title Priority Date Filing Date
CN201110218652.9A Active CN102291396B (zh) 2011-08-01 2011-08-01 可信平台远程证明的匿名认证算法

Country Status (1)

Country Link
CN (1) CN102291396B (zh)

Families Citing this family (6)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN104506532B (zh) * 2014-12-24 2018-06-26 北京智捷伟讯科技有限公司 一种适用于紧急救援平台的远程证明方法
CN104917615B (zh) * 2015-04-24 2018-06-01 广东电网有限责任公司信息中心 一种基于环签名的可信计算平台属性验证方法
CN105187213B (zh) * 2015-08-12 2018-05-22 四川神琥科技有限公司 一种计算机信息安全的方法
CN105376240B (zh) * 2015-11-26 2018-07-06 合肥高维数据技术有限公司 一种不需可信第三方的匿名提交系统
CN109308417B (zh) * 2017-07-27 2022-11-01 阿里巴巴集团控股有限公司 基于可信计算的解锁方法及装置
CN108390866B (zh) * 2018-02-06 2020-10-02 南京航空航天大学 基于双代理双向匿名认证的可信远程证明方法及系统

Citations (2)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN201127035Y (zh) * 2007-09-03 2008-10-01 北京派瑞根科技开发有限公司 基于互联网络的县志系统
CN101964786A (zh) * 2010-09-17 2011-02-02 中山大学 一种基于机顶盒的信息安全传输系统及方法

Family Cites Families (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US20080104417A1 (en) * 2006-10-25 2008-05-01 Nachtigall Ernest H System and method for file encryption and decryption

Patent Citations (2)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN201127035Y (zh) * 2007-09-03 2008-10-01 北京派瑞根科技开发有限公司 基于互联网络的县志系统
CN101964786A (zh) * 2010-09-17 2011-02-02 中山大学 一种基于机顶盒的信息安全传输系统及方法

Also Published As

Publication number Publication date
CN102291396A (zh) 2011-12-21

Similar Documents

Publication Publication Date Title
US10944575B2 (en) Implicitly certified digital signatures
CN109584978B (zh) 基于签名聚合医疗健康监控网络模型信息处理方法及系统
EP2533457B1 (en) Secure implicit certificate chaining
CN101931529B (zh) 一种数据加密方法、数据解密方法及节点
CN110545279A (zh) 兼具隐私和监管功能的区块链交易方法、装置及系统
CN101296075B (zh) 一种基于椭圆曲线的身份认证系统
CN103414569A (zh) 一种建立抗攻击的公钥密码的方法
CN102291396B (zh) 可信平台远程证明的匿名认证算法
CN101931536B (zh) 一种无需认证中心的高效数据加密及认证方法
CN114491578B (zh) 一种用于隐私计算的安全数据聚合方法
Bai et al. Elliptic curve cryptography based security framework for Internet of Things (IoT) enabled smart card
CN104301108A (zh) 一种从基于身份环境到无证书环境的签密方法
CN107864037A (zh) Sm9联合数字签名方法和装置
CN114095181B (zh) 一种基于国密算法的门限环签名方法及系统
CN108390866B (zh) 基于双代理双向匿名认证的可信远程证明方法及系统
CN114448641A (zh) 一种隐私加密方法、电子设备、存储介质以及芯片
CN112350820B (zh) 多接收者签密方法、发送端、接收端、系统及存储介质
CN103346999B (zh) 一种支持not运算符并具有cca安全的cp-abe方法
CN104917615A (zh) 一种基于环签名的可信计算平台属性验证方法
Jiang et al. An anonymous communication scheme based on ring signature in VANETs
CN108933659A (zh) 一种智能电网的身份验证系统及验证方法
Wang et al. On the security of an anonymous batch authenticated and key agreement scheme for value-added services in VANETs
JP5004086B2 (ja) 短い系列を用いた認証システム
KR20170087120A (ko) 무인증서 공개키 암호 시스템 및 수신 단말기
Datta Zero knowledge one time digital signature scheme

Legal Events

Date Code Title Description
C06 Publication
PB01 Publication
C10 Entry into substantive examination
SE01 Entry into force of request for substantive examination
C14 Grant of patent or utility model
GR01 Patent grant