1第5章Hash函数与数字签名2第5章Hash函数与数字签名5.6数字签名概念5.7RSA数字签名体制5.8ElGamal数字签名体制5.9其它数字签名方案5.10数字签名标准5.11应用35.6数字签名概念在政治、军事、外交、商业和日常生活中,人们经常需要对纸质材料进行签名。签名起到确认、核准、生效和负责任等多种作用。随着计算机网络技术的发展,电子商务、电子政务和电子金融等系统得到广泛应用,人们需要通过网络信息传输对电子的文件、契约、合同、信件和张单等进行数字签名以替代手写签名。45.6数字签名概念签名是证明当事人的身份和数据真实性的一种信息。在传统的以书面文件为基础的事物处理中,采用书面签名的形式,如手签、手印和印章等。书面签名得到司法部门的支持,具有一定的法律意义55.6数字签名概念在以计算机文件为基础的现代事物处理中,应采用电子形式的签名,即数字签名(digitalsignature)。数字签名的目的是提供一种手段,使得一个实体把他的身份与某个信息捆绑在一起。一个信息的数字签名实际上是一个数,它仅仅依赖于签名者的密钥和被签名的消息。10011100010100011000sigK密钥K65.6.1数字签名的基本概念(1)消息空间:由所有任意长度消息组成的集合=*MA(2)签名空间:由所有签名组成的集合。签名长度不超过n。nii1AC(3)密钥空间:K(4).:sig,sig,CMSKSKKK.存在签名算法任给密钥签名算法族sigK称为签名算法(signingalgorithm)),,,,(VSKCM一个数字签名体制是一个满足以下条件的五元组:75.6.1数字签名的基本概念(5)verK称为验证算法(verificationalgorithm)}.,{:ver,ver,假真存在验证算法任给密钥验证算法族CMVKVKKK.(6))(sig,)(sig,),(ver,versig,xyxyyxyxKKKKKK假真都有和每一个签名对每一个消息满足:与验证算法签名算法任给密钥CMK,)(sig,CMxyxK如果任给消息则将数据对(x,y)称为消息x的一个数字签名,或直接把y称为消息x的数字签名85.6.1数字签名的基本概念数字签名基本要求对每一个密钥K,sigK和verK应该是多项式时间函数verK是公开的函数,而sigK是保密的给定一个消息x,除了发送者本人以外,任何其他人找到满足verK(x,y)为真的数字签名y,应该是计算上不可行的如果攻击者能够找到满足verK(x,y)的数据对(x,y),而发送者事先又没有对x签名,则称y是伪造(forgery)的数字签名。数字签名算法必须满足的条件签名者事后不能否认自己的签名;其他人不能伪造签名;当通信双方为签名真伪发生争执时,可以由第三方解决争端95.6.1数字签名的基本概念手写签名与数字签名的区别手写签名是所签文件的物理组成部分,数字签名必须与所签文件捆绑在一起。手写签名通过与标准签名进行比较或检查笔迹来验证,数字签名是通过验证算法来验证。手写签名容易伪造,好的数字签名算法应该使伪造签名十分困难。手写签名不易复制。数字签名是一个二进制串,容易复制。所以必须防止数字签名重复使用。105.6.1数字签名的基本概念签名算法进行分类按应用目的普通数字签名特殊目的数字签名:不可否认数字签名、盲签名、群签名等按验证方法在验证时需要输入被签名信息在验证时自动恢复被签名信息按签名时是否使用随机数分成确定性数字签名随机数字签名115.6.2数字签名的基本构造方法利用Hash函数和加密算法可以构造有效的数字签名方案。基于Hash函数和单钥密码算法构造数字签名125.6.2数字签名的基本构造方法基于Hash函数和双钥密码算法构造数字签名135.6.2数字签名的基本构造方法具有保密作用的数字签名双钥密码体制:SK是发送方的私钥,PK是发送方的公钥,E1和D1分别是加密算法与解密算法。单钥密码体制密钥:K是双方公用密钥,E2和D2分别是对应的加密算法和解密算法。145.6.3数字签名的安全需求数字签名的攻击模型唯密钥攻击(keyonlyattack)攻击者E拥有签名者A的公钥K,因而能够计算验证函数verK。已知消息攻击(knownmessageattack)攻击者E拥有一系列以前由签名者A所签名的消息。即E具有数据对(xi,yi),其中xi是消息,yi=sigK(xi)是A对xi的签名(i=1,2,…)。选择消息攻击(chosenmessageattack)攻击者E可以选择一些消息请求签名者A签名。即E选择消息xi,并将xi发送给签名者A,请求A对xi签名。A计算yi=sigK(xi),并将yi发给E。所以,E具有A的有效数字签名(xi,yi)(i=1,2,…)。155.6.3数字签名的安全需求攻击者对数字签名系统的攻击目的完全破译(totalbreak)攻击者E能确定签名者A的私钥K,因而能够计算签名函数sigK,可以对任何消息产生有效的签名。选择性伪造(selectiveforgery)攻击者E能以某一个不可忽略的概率对另外某个人选定的消息产生一个有效的签名。也就是说,如果给E选定一个消息x,那么他能以一个正的概率找到x的签名y=sigK(x),并且签名者A以前未对x签名。存在性伪造(existentialforgery)攻击者E至少能够为一个消息产生一个有效的签名。也就是说,E可能生成一个数据对(x,y),其中x是消息,y=sigK(x)。签名者A以前未对x签名。165.6.3数字签名的安全需求Hash函数与数字签名的安全性对消息的散列值签名175.6.3数字签名的安全需求使用已知消息攻击的存在性伪造攻击者E从一个有效的签名(x,y)开始,其中y=sigK(h(x)).然后他计算z=h(x),并企图找到x’x,使得h(x’)=h(x).如果E能做到这一点,则(x’,y)就是一个有效的签名,从而y是消息x’的一个伪造签名.为了阻止这种攻击,必须要求Hash函数h是弱无碰撞的.使用选择消息攻击的存在性伪造攻击者E首先找到x’x,使得h(x’)=h(x).然后将消息x发给签名者A,并让A对消息的散列值h(x)签名,从而得到y=sigK(h(x)).所以E能够成功伪造签名(x’,y).为了阻止这种攻击,必须要求Hash函数h是强无碰撞的.185.6.3数字签名的安全需求使用唯密钥攻击的存在性伪造当签名算法遭到唯密钥攻击时,即攻击者E拥有签名者A的公钥K.E就可能对一个随机的散列值z伪造签名y=sigK(z).此时,如果Hash函数h不是单向的,则E可能找到一个消息x,使得z=h(x).所以E能够成功伪造一个签名(x,y).为了阻止这种攻击,必须要求Hash函数h是单向的.19第5章Hash函数与数字签名5.6数字签名概念5.7RSA数字签名体制5.8ElGamal数字签名体制5.9其它数字签名方案5.10数字签名标准5.11应用205.7RSA数字签名体制利用RSA加密算法构造的数字签名称为RAS数字签名体制。5.7.1RSA算法描述1.密钥生成算法选取两个大素数p,q,计算n=pq,(n)=(p1)(q1)。任选整数e,满足:0e(n),且gcd(e,(n))=1。用扩展Euclidean算法求e模(n)的逆d,即ed=1mod(n)。签名者的公钥:{n,e},私钥:{p,q,d}。215.7.1RSA算法描述2.签名算法设消息为x,则x的RAS签名是=mod.dyxn3.验证算法当接收方收到签名(x,y)后,计算如果x=x’,则y是x的RAS签名。.mod,nyxe225.7.2RSA数字签名的安全性1.一般攻击攻击方法:设n与e为用户A的公钥,攻击者首先随意选择一个数据y,并用A的公钥计算x=yemodn,于是可以伪造A的一个RSA数字签名(x,y)。因为xd=(ye)d=yed=ymodn,所以用户A对x的RSA数字签名是y。这种攻击实际上成功的概率是不高的因为对于选择的数据y,得到的x=yemodn具有正确语义的概率是很低的。抵抗措施仔细设计数据格式对数据的Hash值进行签名235.7.2RSA数字签名的安全性2.选择消息攻击攻击方法:假设攻击者E想伪造消息x的签名,他容易找到两个数据x1和x2,使得12=mod.xxxn攻击者E设法让用户A分别对x1和x2进行签名,得到.mod,mod2211nxynxydd然后E可以计算121212==()=mod.ddddyyyxxxxxn于是攻击者E得到了用户A对消息x的RSA数字签名y抵抗措施用户不要轻易地对其他人提供的随机数据进行签名对数据的Hash值进行签名245.7.2RSA数字签名的安全性3.利用签名进行攻击从而获得明文攻击方法假设攻击者E已截获了秘文c=xemodn,他想求出明文x。于是,他选择一个小的随机数r,并计算因为s=re,所以sd=(re)d=modn,r=sdmodn.然后E设法让签名者对l签名.于是E又获得k=ldmodn.攻击者E再计算:.mod,mod,mod1nrtncslnrse.mod111nxccrrcsrlrktddddd于是,获得了秘文x。抵抗措施用户不要轻易地对其他人提供的随机数据进行签名对数据的Hash值进行签名255.7.2RSA数字签名的安全性4.对先加密后签名方案的攻击攻击方法假设签名者A采用先加密后签名的方案把消息x发送给接收者B,则他先用B的公开密钥eB对x加密,然后用自己的私钥dA签名.设A的模数为nA,B的模数为nB.于是A发送给B的数据为:.mod)mod(AdBennxAB如果B是不诚实的,那么B可能伪造A的签名.例如,假设B想抵赖收到A发的消息x,慌称收到的是x1.因为nB是B的模数,所以B知道nB的分解,于是能够计算模nB的离散对数.即他能找到k满足:.mod)(1Bknxx然后,B再公布他的新公开密钥为keB。现在B宣布他收到的消息是x1,而不是x。由于下式成立,所以A无法争辩。AdBeAdBkennxnnxABABmod)mod(mod)mod(1265.7.2RSA数字签名的安全性4.对先加密后签名方案的攻击抵抗措施签名者A应当在发送的数据中加入时间戳,从而可证明是用公开密钥eB对x加密,而不是用新公开密钥keB对x1加密。对数据的Hash值进行签名。综上所述,对于RSA数字签名系统,必须采取如下安全措施:不直接对消息进行签名,而应该对消息的Hash值进行签名。要采用先签名后加密的方式,而不要采用先加密后签名的方式。27第5章Hash函数与数字签名5.6数字签名概念5.7RSA数字签名体制5.8ElGamal数字签名体制5.9其它数字签名方案5.10数字签名标准5.11应用285.8ElGamal数字签名体制在1985年,ElGamalT.提出了一个基于离散对数问题的数字签名体制,通常称为ElGamal数字签名体制。ElGamal签名体制的安全性主要是基于有限域上离散对数问题的难解性。295.8.1ElGamal签名算法描述1.参数生成算法选取一个大素数p,gZp*是一个本原元,p和g是系统公开参数。任选整数x,满足:1≤x≤p2。计算y=gxmodp.签名者的公钥为y,私钥为x。2.签名算法设MZp*为待签名的消息。签名者随机选择一个秘密整数k,1≤k≤p2,计算).1(mod)(,mod1pkrxMspgrk签名者对M的ElGamal签名为:.),()sig(*1*ppZZsrM签名者将数据(M,(r,s))发送给接收者。305.8.1ElGamal签名算法描述3.验证算法